共享内存是被多个进程共享一部分物理内存。共享内存是进程间共享数据的最快的方法,一个进程向共享内存区写入数据,共享这个内存区的所有进程可以立刻看到其中的内容。
共享内存的实现步骤:
1.创建共享内存,使用shmget函数。
int shmget(key_t key,int size,int shmflg)
key为共享内存的键值,一般取IPC_PRIVATE。创建成功则返回内存标识符,创建失败,返回-1.
2.映射共享内存,将这段创建的共享内存映射到具体的进程空间,使用shmat函数。
int shmat(int shmid,char *shmaddr,int flag)
shmid为shmget函数返回的共享内存标识符,flag决定以什么方式确定映射地址(物理内存在不同进程中对应不同的地址),映射地址(shmaddr通常为0)
如果映射成功,返回共享内存映射到进程中的地址,如果失败,返回-1。
3.结束共享内存
int shmdt(char *shmaddr)
shmaddr来自2中的shmaddr。
#include<sys/stat.h>
#include<sys/types.h>
#include<sys/ipc.h>
#include<sys/shm.h>
#include<unistd.h>
#include<errno.h>
#include<string.h>
#include<stdlib.h>
#include<stdio.h>
#define PERM S_IRUSR|S_IWUSR
int main(int argc,char **argv)
{
int shmid;
char *p_addr,*c_addr;
if(argc!=2)
{
fprintf(stderr,"Usage:%s\n\a",argv[0]);
exit(1);
}
/*创建共享内存*/
if((shmid=shmget(IPC_PRIVATE,1024,PERM))==-1)
{
fprintf(stderr,"Create Share Memory Error:%s\n\a",strerror(errno));
exit(1);
}
/*创建子进程*/
if(fork())
{
p_addr=shmat(shmid,0,0);
memset(p_addr,'\0',1024);
strncpy(p_addr,argv[1],1024);
wait(NULL);
exit(0);
}
else
{
sleep(1);
c_addr=shmat(shmid,0,0);
printf("Client get %s\n",c_addr);
exit(0);
}
}