概述
是进程间通信中最简单的方式之中的一个。共享内存同意两个或很多其他进程訪问同一块内存,就如同 malloc() 函数向不同进程返回了指向同一个物理内存区域的指针。
当一个进程改变了这块地址中的内容的时候,其他进程都会察觉到这个更改。
共享内存的特点:
1)共享内存是进程间共享数据的一种最快的方法。
2)使用共享内存要注意的是多个进程之间对一个给定存储区訪问的相互排斥。
经常使用函数
1)创建共享内存
所需头文件:
int shmget(key_t key, size_t size,int shmflg);
功能:
參数:
返回值:
演示样例代码例如以下:#include
#include
#include
#include
#include
#include
#include
#define BUFSZ 1024
int main(int argc, char *argv[])
{
int shmid;
key_t key;
key = ftok("./", 2015);
if(key == -1)
{
perror("ftok");
}
//创建共享内存
shmid = shmget(key, BUFSZ, IPC_CREAT|0666);
if(shmid < 0)
{
perror("shmget");
exit(-1);
}
return 0;
}
执行结果例如以下:
2)共享内存映射
所需头文件:
void *shmat(int shmid, const void *shmaddr, int shmflg);
功能:
參数:
返回值:
3)解除共享内存映射
所需头文件:
int shmdt(const void *shmaddr);
功能:
參数:
返回值:
4)共享内存控制
所需的头文件:
#include
#include
int shmctl(int shmid, int cmd, struct shmid_ds *buf);
功能:
參数:
返回值:
实战演示样例
接下来我们做这么一个样例:创建两个进程,在 A 进程中创建一个共享内存,并向其写入数据。通过 B 进程从共享内存中读取数据。
写端代码例如以下:#include
#include
#include
#include
#include
#include
#include
#define BUFSZ 512
int main(int argc, char *argv[])
{
int shmid;
int ret;
key_t key;
char *shmadd;
//创建key值
key = ftok("../", 2015);
if(key == -1)
{
perror("ftok");
}
//创建共享内存
shmid = shmget(key, BUFSZ, IPC_CREAT|0666);
if(shmid < 0)
{
perror("shmget");
exit(-1);
}
//映射
shmadd = shmat(shmid, NULL, 0);
if(shmadd < 0)
{
perror("shmat");
_exit(-1);
}
//拷贝数据至共享内存区
printf("copy data to shared-memory\n");
bzero(shmadd, BUFSZ); // 共享内存清空
strcpy(shmadd, "how are you, mike\n");
return 0;
}
读端代码例如以下:#include
#include
#include
#include
#include
#include
#include
#define BUFSZ 512
int main(int argc, char *argv[])
{
int shmid;
int ret;
key_t key;
char *shmadd;
//创建key值
key = ftok("../", 2015);
if(key == -1)
{
perror("ftok");
}
system("ipcs -m"); //查看共享内存
//打开共享内存
shmid = shmget(key, BUFSZ, IPC_CREAT|0666);
if(shmid < 0)
{
perror("shmget");
exit(-1);
}
//映射
shmadd = shmat(shmid, NULL, 0);
if(shmadd < 0)
{
perror("shmat");
exit(-1);
}
//读共享内存区数据
printf("data = [%s]\n", shmadd);
//分离共享内存和当前进程
ret = shmdt(shmadd);
if(ret < 0)
{
perror("shmdt");
exit(1);
}
else
{
printf("deleted shared-memory\n");
}
//删除共享内存
shmctl(shmid, IPC_RMID, NULL);
system("ipcs -m"); //查看共享内存
return 0;
}
执行结果例如以下: