进程间通信——共享的内存

共享的内存可以说是最有用的进程间通信方式,也是最快的IPC形式。

两个不同进程A、B共享内存的意思是,同一块物理内存被映射到进程A、B各自的进程地址空间。进程A可以即时看到进程B对共享内存中数据的更新,反之亦然。由于多个进程共享同一块内存区域,必然需要某种同步机制,互斥锁和信号量都可以

共享内存允许两个或多个进程共享同一块内存(这块内存会映射到各个进程自己独立的地址空间),从而使得这些进程可以相互通信。

共享内存通信的一个显而易见的好处是效率高,因为进程可以直接读写内存,(无需系统调用!)而不需要任何数据的拷贝。

 

共享内存是由IPC为一个进程所创建,并出现在进程地址空间中的一段特殊的地址。其他进程可以将同样的共享内存段关联到它们自己的地址空间中。

 代码:

 shmget(key, )

 key——可以由用户指定,使用IPC_PRIVATE则由系统产生。

 flag——可以使用0666|IPC_CREAT,表示任意进程可读可写。

返回值: 错误返回-1


映射共享内存:

shmat(shmid, 0, 0)

返回:附接后的地址


shmdt()

返回: 正确0  错误-1

 

 

 

 

 

 

http://wenku.baidu.com/view/dfb8095b804d2b160b4ec090.html

http://blog.csdn.net/pcliuguangtao/article/details/6526119

http://www.ibm.com/developerworks/cn/linux/l-ipc/part5/index1.html 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值