原理
- Linux不同的进程所占用的虚拟内存通过页表映射到不同物理内存,通过专门的函数可以使不同的进程访问到同一块物理内存,这样不同的进程就可以通过直接在这块物理内存中读写数据实现通信。
- 相比于管道通信,共享内存省去了两次拷贝过程,速度更快。
管道通信: 数据从进程一所占用的内存拷贝到管道,再从管道拷贝到进程二,实现通信。
函数接口
#include <sys/types.h>
#include <sys/shm.h>
int shmget(key_t key, size_t size, int shmflg);//创建共享内存
void* shmat(int shmid, const void* shmaddr, int shmflg);//获取共享内存地址(与自己的页表建立映射关系)
int shmdt(const void* shmaddr);//解除映射
int shmctl(int shmid, int cmd, struct shmid_ds* buf);//控制共享内存