共享存储允许两个或多个进程共享一个给定的存储区。因为数据不需要在客户进程和服务器进程之间复制,所以这是最快的一种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
本文介绍了共享存储(interprocess communication)的概念及其实现方式,包括shmget、shmctl、shmat和shmdt等函数的使用方法及其返回值的意义。
529

被折叠的 条评论
为什么被折叠?



