进程间通信-共享存储

共享存储允许两个或多个进程共享一个给定的存储区。因为数据不需要在客户进程和服务器进程之间复制,所以这是最快的一种IPC.

若服务器进程正在将数据放入共享存储区,则在它完成这一操作之前,客户进程不应该去读取这些数据。

内核为每个共享存储段维护一个结构。结构如下:  // 在 /usr/include/linux/shm.h

shmget函数:可以获得一个共享存储标识符

#include <sys/shm.h>
int shmget(key_t key, size_t size, int flag);

执行成功返回共享存储ID,出错返回-1

shmctl函数:操作共享存储段

#include <sys/shm.h>
int shmctl(int shmid, int cmd, struct shmid_ds *buf);

执行成功返回0,出错返回-1

shmat函数:将共享存储段连接到进程的地址空间

#include <sys/shm.h>
void *shmat(int shmid, const void *addr, int flag);

执行成功返回指向共享存储段的指针,失败返回-1

shmdt函数:将shmid_ds结构中的shm_nattch计数器减1

#include <sys/shm.h>
int shmdt(const void *addr);
执行成功返回0,出错返回-1



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值