过程通信-共享内存 听课笔记

进程通信--共享内存 听课笔记
多个进程共享一段物理内存
是进程间共享数据最快的方法

步骤
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); 
	} 
}