多个进程共享一段物理内存
是进程间共享数据最快的方法
步骤
1 创建共享内存, 使用shmget函数
2 映射共享内存, 使用shmat函数, 将共享内存映射到具体的进程空间去
3 解除映射共享内存, 使用shmdt函数
4 删除共享内存, 使用shmctl函数
创建
int shmget(key_t key, int size, int shmflg)
key: 标识共享内存的键值 0 或 IPC_PRIVATE
IPC_PRIVATE-->将创建一块新的共享内存
0------------>参数shmflg又设置IPC_PRIVATE这个标识,同样会创建一块新的共享内存
返回值: 成功返回共享内存标识符, 失败返回-1
映射
void *shmat(int shmid, char *shmaddr, inf flag)
参数:
shmid: shmget返回的共享内存标识符
shmaddr: 共享内存的起始地址, 0-->系统自动分配
flag: 以什么方式来确定映射的地址,通常为0
返回值:
成功则返回共享内存映射到进程中的起始地址
失败返回-1
解除映射
int shmdt(char *shmaddr)
示例:
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <unistd.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.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); // 暂停1秒
c_addr=shmat(shmid,0,0);
printf("Client get %p\n",c_addr);
exit(0);
}
}