共享内存为多个进程之间共享和传递数据提供了一种有效的方式。共享内存是先在物理内存上申请一块空间,多个进程可以将其映射到自己的虚拟地址空间中。所有进程都可以访问共享内存中的地址,就好像它们是由malloc分配的一样。如果某个进程向共享内存写入了数据,所做的改动将立刻被可以访问同一段共享内存的任何进程看到。由于它并未提供同步机制,所以我们通常需要用其他的机制来同步对共享内存的访问。
共享内存示例代码
# include <sys/shm.h> /* shmget()用于创建或者获取共享内存 shmget()成功返回共享内存的ID,失败返回-1 key:不同的进程使用相同的key值可以获取到同一个共享内存 size:创建共享内存时,指定要申请的共享内存空间大小 shmflg:IPC_CREAT IPC_EXCL */ int shmget(key_t key,size_t size,int shmflg); /* shmat()将申请的共享内存的物理地址映射到当前进程的虚拟地址空间上 shmat()成功返回共享内存的首地址,失败返回NULL shmaddr:一般给NULL,由系统自动选择映射的虚拟地址内存 shmflg:一般给0,可以给SHM_RDONLY为只读模式,其他的为读写 */ void*shmat(int shmid,const void*shmaddr,int shmflg); /* shmdt()断开当前进程的shmaddr指向的共享内存映射 shmdt()成功返回0,失败返回-1 */ int shmdt(const void*shmaddr); /* shmctl()控制共享内存 shmctl()成功返回0,失败返回-1 cmd :IPC_RMID */ int shmctl(int shmid,int cmd,struct shmid_ds*buf);
例题:进程a向共享内存中写入数据,进程b从共享内存中读取数据并显示
shma.c代码:
# include <stdio.h> # include <stdlib.h> # include <string.h> # include <unistd.h> # include <assert.h> # include <sys/shm.h> int main () { int shmid=shmget((key_t)1234,128,IPC_CREAT|0600); assert(shmid!=-1); char*s=(char*)shmat(shmid,NULL,0); assert(s!=NULL); strcpy(s,"hello"); shmdt(s); exit(0); }
shmb.c代码如下:
# include <stdio.h> # include <stdlib.h> # include <string.h> # include <unistd.h> # include <assert.h> # include <sys/shm.h> int main () { int shmid=shmget((key_t)1234,128,IPC_CREAT|0600); assert(shmid!=-1); char*s=(char*)shmat(shmid,NULL,0); assert(s!=NULL); printf("shmb s=%s\n",s); shmdt(s); shmctl(shmid,IPC_RMID,NULL); exit(0); }
Linux共享内存
最新推荐文章于 2023-05-18 10:50:41 发布