进程间通信-共享存储

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



猜你喜欢

转载自blog.csdn.net/aabb7012086/article/details/80907388