进程间通讯(四) 共享内存

一、共享内存

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:要进行的事情

注意:共享内存是两个以上的进程能够操作同一块物理空间的内存区域,所以共享的区域就成了临界资源,所以对于共享区域的访问必须做同步控制。(信号量)





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值