1. 共享内存
进程间通信效率最高的通信方式,为了在多个进程间交换信息,内核专门留出了一块内存区,可以由需要访问的进程将其映射到自己的私有地址空间,进程可以直接读写内存,而不需要任何数据的拷贝。
共享内存创建在内核里,谁想用谁映射,映射到用户空间,在用户空间里进行操作。
共享内存是用户空间和内核空间的0次拷贝,其他进程间通信是两次;
2. ipcs [-m|-s|-q]
查看共享信息的内存的命令,默认会列出共享内存、信号量,队列信息,-m列出共享内存,-s列出共享信号量,-q列出共享队列; ipcs -a查看所有的IPC对象使用情况
ipcrm [-m|-s|-q] id
清除命令是-m 删除共享内存,-s删除共享信号量,-q删除共享队列。
3. 共享的内存的使用
1) 必备:ket_t key 由ftok函数产生key值
key_t ftok(const char *pathname, int proj_id );
2) 创建
int shmget(key_t key, size_t size, int shmflg);
//创建或打开一段内存
3) 映射
int shmat(int shmid, const void *shmaddr,int shmflg);
4) 取消映射
int shmdt(const void *shmaddr)