共享内存
共享内存是进程间通信手段速度最快的一种,因为这些进程间的数据传递不需要执行进入内核的系统调用,而是多个进程共享一个公共内存,多个进程通过对内存的直接读写而实现通信
共享内存相关函数
shmget函数
- 功能
- 用来创建共享内存
- 原型
int shmget(key_t key, size_t size, int shmflg);
- 参数
- key-共享内存段的名字
- size-共享内存大小
- shmflg-九个权限标志
- 返回值
- 成功返回非负数,失败返回-1
shmat函数
- 功能
- 将共享内存段连接到进程地址空间
- 原型
void *shmat(int shmid, const void *shmaddr, int shmflg);
- 参数
- shmid-共享内存标识
- shmaddr-指定连接的地址
- shmflg-两个取值为SHM_RND和SHM_RDONLY
- 返回值
- 成功返回一个指针,指向共享内存第一个节,失败返回-1
- 说明
- shmaddr为NULL,核心自动选择⼀一个地址
- shmaddr不为NULL且shmflg无SHM_RND标记,则以shmaddr为连接地址。
- shmaddr不为NULL且shmflg设置了SHM_RND标记,则连接的地址会自动向下调整为SHMLBA的整数倍。公式:shmaddr - (shmaddr % SHMLBA)
- shmflg=SHM_RDONLY,表⽰示连接操作用来只读共享内存
shmdt函数
- 功能
- 将共享内存段与当前进程保持脱离,注意并不是删除共享内存段
- 原型
int shmdt(const void *shmaddr);
- 参数
- shmaddr-由shmat所返回的指针
shmctl函数
- 功能
- 用于控制共享内存
- 原型
int shmctl(int shmid, int cmd, struct shmid_ds *buf);
- 参数
- shmid-由shmget返回的共享内存标识码
- cmd-将要采取的动作
- IPC_STAT-把shmid_ds结构中的数据设置为共享内存的当前关联值
- IPC_SET-在进程有足够权限的a前提下,把共享内存的当前关联值设置为shmid_ds数据结构中给出的值
- IPC_RMID-删除共享内存段
- buf-指向一个保存着共享内存的模式状态和访问权限的数据
- 返回值
- 成功返回0,失败返回-1
共享内存的特点
- 进行通信的进程之间不需要任何关系
- 共享内存之间不提供同步互斥机制,一般用信号来保护资源
- 生命周期随内核,不过一般情况资源由进程主动释放
相关指令
ipcs -m
- 查看当前开辟的共享内存
ipcs -m shmid
- 删除id号为shmid的共享内存资源
代码实现
☛ 共享内存