Linux进程通信之POSIX共享内存

本文详细介绍了Linux下利用mmap实现的POSIX共享内存通信方式,包括mmap函数的使用、内存映射区的大小、进程间通信的两种方式,以及基于mmap的POSIX共享内存的创建和使用。通过匿名内存映射和内存映射文件,实现了亲缘和无亲缘进程间的高效通信,同时强调了同步操作的重要性。
摘要由CSDN通过智能技术生成

前面已经讨论过Linux下个各种进程间的通信方式:管道,FIFO,消息队列,他们的共同特点就是通过内核来进行通信(假设POSIX消息队列也是在内核中实现的,因为POSIX标准并没有限定它的实现方式)。向管道,FIFO,消息队列写入数据需要把数据从进程复制到内核,从这些IPC读取数据的时候又需要把数据从内核复制到进程。所以这种IPC方式往往需要2次在进程和内核之间进行数据的复制,即进程间的通信必须借助内核来传递。如下图所示:


通过内核进行通信的IPC

共享内存也是一种IPC,它是目前可用IPC中最快的,它是使用方式是将同一个内存区映射到共享它的不同进程的地址空间中,这样这些进程间的通信就不再需要通过内核,只需对该共享的内存区域进程操作就可以了,和其他IPC不同的是,共享内存的使用需要用户自己进行同步操作。下图是共享内存区IPC的通信,


共享内存IPC通信

1 mmap系列函数简介

mmap函数主要的功能就是将文件或设备映射到调用进程的地址空间中,当使用mmap映射文件到进程后,就可以直接操作这段虚拟地址进行文件的读写等操作,不必再调用readwrite等系统调用。在很大程度上提高了系统的效率和代码的简洁性。

使用mmap函数的主要目的是:

  • 对普通文件提供内存映射I/O,可以提供无亲缘进程间的通信;
  • 提供匿名内存映射,以供亲缘进程间进行通信。
  •  对shm_open创建的POSIX共享内存区对象进程内存映射,以供无亲缘进程间进行通信。

下面是mmap函数的接口以及说明:

#include <sys/mman.h>
void *mmap(void *start, size_t len, int prot, int flags, int fd, off_t offset);
               //成功返回映射到进程地址空间的起始地址,失败返回MAP_FAILED

start:指定描述符fd应被映射到的进程地址空间内的起始地址,它通常被设置为空指针NULL,这告诉内核自动选择起始地址,该函数的返回值即为fd映射到内存区的起始地址。

len:映射到进程地址空间的字节数,它从被映射文件开头的第offset个字节处开始,offset通常被设置为0。如下图是内存映射文件的一个例子:


内存映射文件的示例

prot:内存映射区的保护由该参数来设定,通常由以下几个值组合而成:

  • PROT_READ:数据可读;
  •  PROT_WRITE:数据可写;
  •  PROT_EXEC:数据可执行;
  •  PROT_NONE
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值