进程间通讯(四) 共享内存
一、共享内存
1、所谓共享内存就是在物理内存创建一块区域,让进程A、B同时共享这块区域,这个和管道很像,但区别是这块区域不是一块单独的区域,而是既可以把它看为进程A的一部分,又可以把它看为是进程B的一部分。如图所示:
2、共享内存也有内核对象来管理共享的内存区域。
3、特点:共享内存是最快的一种IPC机制,在各个进程都有指针直接指向开辟内存区域访问时当作本进程中的一个内存控制直接操作。
4、不论是全局变量还是局部变量、堆区都有自己的空间。文件除外,文件在父子进程之间共享,在其他两个互不相关的进程之间不共享。
5、共享内存的操作:
(1)创建或获取:shmget int shmget ( key_t key, size_t size, int flg );
key:与信号量一样,需要一个参数key,它为共享内存段命名;shmget返回一个共性内存标识符。
size:开辟内存空间的大小。
flg:权限, IPC_CREAT 如果共享内存存在则获取,如果不存在则创建。
(2)链接:第一次创建共享内存时它不能被任何进程访问,如果要用,得先将它连接到一个进程的地址空间中。
void * shmat ( int shmid, void *addr, int flag );
返回值一个指向共享内存首地址的指针
(3)断开链接: int shmdt ( void *ptr );此操作只完成断开链接操作,并不会删除共享内存。
(4)删除内核对象:int shmctl (int shmid, int cmd , struct shmid_ds *buff );
cmd:要进行的事情
注意:共享内存是两个以上的进程能够操作同一块物理空间的内存区域,所以共享的区域就成了临界资源,所以对于共享区域的访问必须做同步控制。(信号量)