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