共享内存
共享内存是Linux中最快的ipc形式。不论是管道还是消息队列,要传递的数据都要通过内核,而共享内存只需要在内存中开辟一部分空间,将该空间映射到共享它的进程的地址空间。以后这些进程间通信就不再涉及到内核,也就是说进程不在执行进入内核的系统调用来传递彼此的数据。
可以在/usr/include/linux/shm.h中查看到该数据结构
需要注意的是:共享内存没有同步互斥,所以有可能引起数据的二义性。
相关函数
这里的函数都可以类比之前的消息队列函数学习
shmget:用来创建共享内存
原型: int shmget(key_t key, size_t size, int shmflg);
参数:
key:仍然是我们用ftok获得的
size:共享内存大小
shmflg:由九个权限标志构成,用法与消息队列相同
返回值:
成功返回一个非负整数,即就是该共享内存的标识码;失败-1;