Linux环境进程间通信: 共享内存

本文介绍了mmap机制,一种通过映射文件或匿名文件实现进程间通信的方法。mmap利用不同进程间的地址空间映射相同的物理内存,实现高效的数据交换。文章还列举了mmap使用时需要注意的事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

详细内容出处:http://www.ibm.com/developerworks/cn/linux/l-ipc/part5/index1.html#toggle

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

以下部分只是阅读后的简单整理

原理

mmap通过映射某个文件来达到任意两个进程之间的通信。另外还可以通过匿名文件映射的方式,

来让有亲属关系的进程也能互相通信。所以mmap方式的共享内存又称为映射内存。

当然如果需要严格控制进程之间通信的同步,可以使用到互斥量或者信号量来控制。

 

mmap的实现方式是通过各个进程不同的地址空间映射相同的物理内存来进行通信的,中间的读写操作

并不会立即反映到文件中,所以效率非常高。

 

注意事项

1. mmap映射的地址空间范围大小可以超过文件的实际大小。

    但是当共享内存写入到文件中时,共享内存中超过部分的内容,并不能反映到文件中。

2. mmap并不能改变文件的大小。

3. mmap使用的时候是分配的实际空间大小是系统page页的整数倍     

4. mmap参数中使用的fd,在mmap后可以直接close(fd)掉

5. 只有调用msync()或者mumap时,才会将共享内存的内容flush到文件中

6. 如果封装mmap相关的内容给其它模块使用的时候,为了防止使用者乱用地址空间进行读写,从而产生SIGBUS信号,

    有可能的情况下,需要判断这次SIGBUS是否是由于使用者误用导致的,如果不是,还是需要重新raise该信号,给默认的sighandler处理程序处理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值