linux使用共享内存实现进程间通信源码

简介: linux使用共享内存实现进程间通信源码
#include<stdio.h>
#include<sys/shm.h>
#include<stdlib.h>
#include<string.h>
#include<sys/ipc.h>
int main()
{
        int shmid;
        char *shmaddr;
        key_t key;
        key = ftok(".",1);//获取key的ID值
        shmid = shmget(key,1024*4,IPC_CREAT|0666);//创建共享内存
        if(shmid == -1){//测试是否创建成功,-1为创建失败
                printf("shmget no OK\n");
                exit(-1);
        }
        shmaddr = shmat(shmid,0,0);//映射
        printf("shmat ok\n");
        strcpy(shmaddr,"liuzhihao");//传递数据
        sleep(5);//睡5秒
        shmdt(shmaddr);//释放共享内存数据
        shmctl(shmid,IPC_RMID,0);删除共享内存
        printf("quit\n");//打印退出
        return 0;
}
~                                                                                                                  
~                       

读的部分

#include<stdio.h>
#include<sys/shm.h>
#include<stdlib.h>
#include<string.h>
#include<sys/ipc.h>
int main()
{
        int shmid;
        char *shmaddr;
        key_t key;
        key = ftok(".",1);//获取key的ID值
        shmid = shmget(key,1024*4,0);//创建共享内存
        if(shmid == -1){
                printf("shmget no OK\n");
                exit(-1);
        }
        shmaddr = shmat(shmid,0,0);//映射
        printf("shmat ok\n");
        printf("data:%s \n",shmaddr);//打印输出数据
        shmdt(shmaddr);//释放读取的数据
        printf("quit\n");//打印关闭
        return 0;
}
~      

写的界面显示

CLC@Embed_Learn:~/liuzhihao$ ./w

shmat ok

quit


读的界面显示

CLC@Embed_Learn:~/liuzhihao$ ./r

shmat ok

data:liuzhihao

quit


查看删除共享内存

CLC@Embed_Learn:~/liuzhihao$ ipcs -m


------ Shared Memory Segments --------

key shmid owner perms bytes nattch status

0x00000000 0 CLC 600 393216 2 dest

0x00000000 32769 CLC 600 393216 2 dest

0x01056453 524290 CLC 666 4096 0


CLC@Embed_Learn:~/liuzhihao$ ipcrm -m 524290

CLC@Embed_Learn:~/liuzhihao$ ipcs -m


------ Shared Memory Segments --------

key shmid owner perms bytes nattch status

0x00000000 0 CLC 600 393216 2 dest

0x00000000 32769 CLC 600 393216 2 dest

相关文章
|
2天前
|
消息中间件 存储 网络协议
从零开始掌握进程间通信:管道、信号、消息队列、共享内存大揭秘
本文详细介绍了进程间通信(IPC)的六种主要方式:管道、信号、消息队列、共享内存、信号量和套接字。每种方式都有其特点和适用场景,如管道适用于父子进程间的通信,消息队列能传递结构化数据,共享内存提供高速数据交换,信号量用于同步控制,套接字支持跨网络通信。通过对比和分析,帮助读者理解并选择合适的IPC机制,以提高系统性能和可靠性。
48 14
|
6天前
|
缓存 Linux
linux 手动释放内存
在 Linux 系统中,内存管理通常自动处理,但业务繁忙时缓存占用过多可能导致内存不足,影响性能。此时可在业务闲时手动释放内存。
53 17
|
1月前
|
算法 Linux 调度
深入理解Linux操作系统的进程管理
本文旨在探讨Linux操作系统中的进程管理机制,包括进程的创建、执行、调度和终止等环节。通过对Linux内核中相关模块的分析,揭示其高效的进程管理策略,为开发者提供优化程序性能和资源利用率的参考。
73 1
|
9天前
|
消息中间件 Linux
Linux:进程间通信(共享内存详细讲解以及小项目使用和相关指令、消息队列、信号量)
通过上述讲解和代码示例,您可以理解和实现Linux系统中的进程间通信机制,包括共享内存、消息队列和信号量。这些机制在实际开发中非常重要,能够提高系统的并发处理能力和数据通信效率。希望本文能为您的学习和开发提供实用的指导和帮助。
61 20
|
29天前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
97 13
|
30天前
|
运维 监控 Ubuntu
【运维】如何在Ubuntu中设置一个内存守护进程来确保内存不会溢出
通过设置内存守护进程,可以有效监控和管理系统内存使用情况,防止内存溢出带来的系统崩溃和服务中断。本文介绍了如何在Ubuntu中编写和配置内存守护脚本,并将其设置为systemd服务。通过这种方式,可以在内存使用超过设定阈值时自动采取措施,确保系统稳定运行。
64 4
|
1月前
|
SQL 运维 监控
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
南大通用GBase 8a MPP Cluster Linux端SQL进程监控工具
|
1月前
|
C语言 开发者 内存技术
探索操作系统核心:从进程管理到内存分配
本文将深入探讨操作系统的两大核心功能——进程管理和内存分配。通过直观的代码示例,我们将了解如何在操作系统中实现这些基本功能,以及它们如何影响系统性能和稳定性。文章旨在为读者提供一个清晰的操作系统内部工作机制视角,同时强调理解和掌握这些概念对于任何软件开发人员的重要性。
|
1月前
|
算法 Linux
深入探索Linux内核的内存管理机制
本文旨在为读者提供对Linux操作系统内核中内存管理机制的深入理解。通过探讨Linux内核如何高效地分配、回收和优化内存资源,我们揭示了这一复杂系统背后的原理及其对系统性能的影响。不同于常规的摘要,本文将直接进入主题,不包含背景信息或研究目的等标准部分,而是专注于技术细节和实际操作。
|
1月前
|
Linux 调度 C语言
深入理解操作系统:从进程管理到内存优化
本文旨在为读者提供一次深入浅出的操作系统之旅,从进程管理的基本概念出发,逐步探索到内存管理的高级技巧。我们将通过实际代码示例,揭示操作系统如何高效地调度和优化资源,确保系统稳定运行。无论你是初学者还是有一定基础的开发者,这篇文章都将为你打开一扇了解操作系统深层工作原理的大门。

热门文章

最新文章