一、什么是共享内存?
共享内存(Shared Memory),指两个或多个进程共享一个给定的存储区。
二、特点
-
共享内存是最快的一种 IPC,因为进程是直接对内存进行存取。
-
因为多个进程可以同时操作,所以需要进行同步。
-
信号量+共享内存通常结合在一起使用,信号量用来同步对共享内存的访问。
三、常用API
1.创建/获取共享内存
#include <sys/ipc.h>
#include <sys/shm.h>
int shmget(key_t key, size_t size, int shmflg);
参数:
key_t key: IPC键值
size_t size: 共享内存的大小
int shmflg: 共享内存的权限,如:IPC_CREAT|0666
IPC_CREAT:如果不存在就创建
IPC_EXCL:如果已经存在则返回失败
返回值:成功:返回共享内存标识符,失败:返回-1
2.连接共享内存
#include <sys/types.h>
#include <sys/shm.h>
void *shmat(int shmid, const void *shmaddr, int shmflg);
参数:
int shmid: 共享内存标识符
const void *shmaddr: 共享内存映射地址,默认写0
int shmflg: 共享内存具有可读可写权限,默认写0
返回值:成功:返回共享内存段映射地址,失败:-1
3.断开共享内存
#include <sys/types.h>
#include <sys/shm.h>
int shmdt(const void *shmaddr);
参数:const void *shmaddr:共享内存映射地址
返回值:成功0,失败-1
4.控制共享内存
#include <sys/ipc.h>
#include <sys/shm.h>
int shmctl(int shmid, int cmd, struct shmid_ds *buf);
参数:
int shmid: 共享内存标识符
int cmd: 一个指令,一般写删除指令:IPC_RMID
struct shmid_ds *buf: 一个buf,一般写0
四、编程示例
shmw.c
#include <stdio.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <stdlib.h>
#include <sys/types.h>
#include <string.h>
int main()
{
int shmid;
char *shmaddr;
key_t key;
key = ftok(".",1);
shmid = shmget(key,1024*4,IPC_CREAT|0666);//创建/获取共享内存
if(shmid == -1){
printf("shmget failed\n");
exit(-1);
}
exit(0);
shmaddr = shmat(shmid,0,0);//映射地址空间,连接共享内存
printf("shmat success\n");
strcpy(shmaddr,"gaoyingjie");
sleep(5);
shmdt(shmaddr);//断开共享内存
shmctl(shmid,IPC_RMID,0);//删除共享内存
printf("quit\n");
return 0;
}
shmr.c
#include <stdio.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <stdlib.h>
#include <sys/types.h>
#include <string.h>
int main()
{
int shmid;
char *shmaddr;
key_t key;
key = ftok(".",1);
shmid = shmget(key,1024*4,IPC_CREAT|0666);//创建/获取共享内存
if(shmid == -1){
printf("shmget failed\n");
exit(-1);
}
shmaddr = shmat(shmid,0,0);//连接共享内存
printf("shmat success\n");
printf("data:%s\n",shmaddr);
shmdt(shmaddr);//断开共享内存
printf("quit\n");
return 0;
}
查看共享内存:ipcs -m
删除共享内存:ipcrm -m + shmid号