共享内存是同一机子上进程间通信最快的方法,一个进程可以创建一个共享内存区域,另一个内存可以访问该区域。,如果你需要高性能的同机进程间通信的时候,就可以使用共享内存。
共享内存相关的函数:
int shmget(key_t key, size_t size, int shmflg);
void *shmat(int shmid,const void *shmaddr, int shmflg);
int shmdt(const void * shmaddr);
int shmctl(int shmid, int cmd,struct shmid_ds *buf);
#include<sys/ipc.h>
#include<sys/shm.h>
int shmget(key_t key, size_t size, int shmflg);
参数:
key为用ftok()函数产生的唯一的键
size为共享内存的大小,实际分配的空间大小为PAGE_SIZE大小的整数倍
shmflg访问标志符,其值有:
IPC_CREAT:这个标志表示应创建一个新的共享内存块。通过指定这个标志,我们可以创建一个具有指定键值的新共享内存块。 如果该共享内存块已经存在,系统会检查访问权限后返回。
IPC_EXCL:这个标志只能与 IPC_CREAT 同时使用。当指定这个标志的时候,如果已有一个具有这个键值的共享内存块存在,则shmget会调用失败。
返回值:成功则返回标志符,失败返回-1
#include<sys/ipc.h>
#include<sys/shm.h>
void *shmat(int shmid,const void *shmaddr, int shmflg);
参数说明:
shmid:共享内存的标志符,由shmget函数返回
shmaddr:指定共享内存出现在进程内存地址的什么位置,通常我们让内核自己决定一个合适的地址位置,用的时候设为0。
shmflg:制定特殊的标志位。其取值SHM_RND,SHMLBA,SHM_RDONLY,SHM_REMAP。
返回值:成功返回被链接的共享内存的地址,失败返回(void*)-1
#include<sys/ipc.h>
#include<sys/shm.h>
int shmdt(const void * shmaddr);
参数说明:
shmaddr由shmat返回的地址
返回值:成功返回0,失败返回-1
#include<sys/ipc.h>
#include<sys/shm.h>
int shmctl(int shmid, int cmd,struct shmid_ds *buf);
参数说明:
shmid:是共享内存的ID。
cmd: 是控制命令,可取值如下:
IPC_STAT 得到共享内存的状态,
IPC_SET 改变共享内存的状态
IPC_RMID 删除共享内存
struct shmid_ds *buf是一个结构体指针。IPC_STAT的时候,取得的状态放在这个结构体中。如果要改变共享内存的状态,用这个结构体指定。
返回值: 成功返回0,失败返回-1
例子:writetosharedmemory.c
readfromsharedmemory.c
先运行writetosharedmemory,后运行readfromsharedmemory
可参见http://www.blogjava.net/sunzhong/articles/297435.html
http://baike.baidu.com/view/3025906.htm
http://www.ibm.com/developerworks/cn/linux/l-ipc/part5/index1.html