一 概述
共享内存是进程间通信中最简单的方式之一。共享内存允许两个或更多进程访问同一块内存,就如同 malloc() 函数向不同进程返回了指向同一个物理内存区域的指针。当一个进程改变了这块地址中的内容的时候,其它进程都会察觉到这个更改。
二 优势
1 ipc通信中最快的一种方式。
原因:两个进程地址通过页表映射到同一片物理地址,进程传递的数据直接从内存里存取、放入,数据不需要在两进程间复制
2 共享内存的生命周期随内核。
即所有访问共享内存区域对象的进程都已经正常结束,共享内存区域对象仍然在内核中存在(除非显式删除共享内存区域对象),
三 劣势
1 共享内存为提供同步机制,基于此,我们通常会用信号量来实现对共享内存同步访问控制。
2 进程需要在同一台主机
四 函数
// 所有的函数需要的头文件
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
1 shmget
int shmget(key_t key, size_t size, int shmflg)
函数作用: 创建共享内存
返回值: 成功:共享内存标识符 失败: -1
参数:
key: 进程间通信键值(唯一非零),ftok() 的返回值。
size: 共享内存的大小,它的值一般为一页大小的整数倍(未到一页,操作系统向上对齐到一页,但是用户实际能使用只有自己所申请的大小)。
shmflg:创建共享的一组标志
例如:
IPC_CREAT: 根据key创建一个新的共享内存。如果已经存在,则返回已经存在的标识
IPC_CREAT | IPC_EXCL: 据key创建一个新的共享内存。如果已经存在,则返回错误
2 shmat
void *shmat(int shm_id, const void *shm_addr, int shmflg);
函数作用: 共享内存的映射
函数返回值: 成功:共享内存段映射地址(相当于这个指针就指向此共享内存) 失败:-1
参数:
shm_id是由shmget函数返回的共享内存标识。
shm_addr指定共享内存连接到当前进程中的地址位置,通常为空,表示让系统来选择共享内存的地址。
shm_flg是一组标志位,通常为0
3 shmdt
int shmdt(const void *shmaddr)
函数作用: 解除共享内存的映射
返回值: 成功:0 失败:-1
参数:
shmaddr:共享内存映射地址
4 shmctl
int shmctl(int shmid, int cmd, struct shmid_ds *buf);
函数作用: 共享内存属性的控制。
返回值: 成功:0 失败:-1
参数:
shmid:共享内存标识符。
cmd:函数功能的控制,其取值如下:
IPC_RMID:删除。(常用 )
IPC_SET:设置 shmid_ds 参数,相当于把共享内存原来的属性值替换为 buf 里的属性值。
IPC_STAT:保存 shmid_ds 参数,把共享内存原来的属性值备份到 buf 里。
SHM_LOCK:锁定共享内存段( 超级用户 )。
SHM_UNLOCK:解锁共享内存段。
SHM_LOCK 用于锁定内存,禁止内存交换。并不代表共享内存被锁定后禁止其它进程访问
其真正的意义是:被锁定的内存不允许被交换到虚拟内存中。这样做的优势在
于让共享内存一直处于内存中,从而提高程序性能。
buf:shmid_ds 数据类型的地址(具体类型请点此链接 ),用来存放或修改共享内存的属性。
四 举例: