Linux进程间通信之共享存储
一、定义:共享存储允许两个或多个进程共享一个给定的存储区。因为数据不需要在客户进程和服务器之间复制,所以这是最快的之中IPC。
使用共享存储时要掌握的唯一窍门是,在多个进程之间同步访问一个给定的存储区。若服务器进程正在将数据放入共享存储区,则在它做完这一操作之前,客户进程不应当去取这些数据。通常,信号量用于同步共享存储访问。(不过正如部分所述,也可以用记录锁或者互斥量)
二、特点:
1.共享内存是最快的一种 IPC,因为进程是直接对内存进行存取。
2.因为多个进程可以同时操作,所以需要进行同步。
3.信号量+共享内存通常结合在一起使用,信号量用来同步对共享内存的访问。
三、相关函数:
1.函数shmget
NAME
shmget - allocates a shared memory segment
SYNOPSIS
#include <sys/ipc.h>
#include <sys/shm.h>
int shmget(key_t key, size_t size, int shmflg);
//返回值:成功返回共享内存ID,失败返回-1
①功能:创建或获取一个共享内存。
②参数:
*key:键。
*size:是该共享存储的长度,以字节为单位。
实现通常将其向上取为系统页长的整倍数。但是,若应用指定的size值并非系统页长的整倍数,那么最后一页的余下部分是不可使用的。如果正在创建一个新段(通常在服务器进行中),则必须指定其size。如果正在引用一个现存的段(一个客户进程),则将size指定为0.当创建一个新段时,段内的内容初始化为0.
*flag:
① 0:取共享内存标识符,若不存在则函数会报错
② PC_CREAT:当shmflg&IPC_CREAT为真时,如果内核中不存在键值与key相等。
的共享内存,则新建一个共享内存;如果存在这样的共享内存,返回此共享内存的标识符。
③ IPC_CREAT|IPC_EXCL:如果内核中不存在键值 与key相等的共享内存,则新建一个共享内存;如果存在这样的共享内存则报错。
2.函数shmat
void *shmat(int shmid, const void *addr, int flag)