linux——进程间通信(共享内存)

概念
通俗的说就是两个进程同享一段公共的内存空间,这段空间就叫共享内存,共享内存的数据两个进程都可以访问,可对其写数据,也可对其读数据。共享内存是两个单独进程之间的通信,两个进程之间可以没有任何关系。
图解
linux——进程间通信(共享内存)_第1张图片
内存共享函数

int shmget(key_t key, size_t size, int shmflg);
参数
	key:这个共享内存段名字
	size:共享内存大小
	shmflg:由九个权限标志构成,它们的用法和创建文件时使用的mode模式标志是一样的
返回值:
	成功返回一个非负整数,即该共享内存段的标识码;失败返回-1


void *shmat(int shmid, const void *shmaddr, int shmflg);
参数
	shmid: 共享内存标识
	shmaddr:指定连接的地址
	shmflg:它的两个可能取值是SHM_RND和SHM_RDONLY
返回值:
	成功返回一个指针,指向共享内存第一个节;失败返回-1


int shmdt(const void *shmaddr);
参数
	shmaddr: 由shmat所返回的指针
返回值:
	成功返回0;失败返回-1
注意:将共享内存段与当前进程脱离不等于删除共享内存段

int shmctl(int shmid, int cmd, struct shmid_ds *buf);
参数
	shmid:由shmget返回的共享内存标识码
	cmd:将要采取的动作(有三个可取值),如下表
	buf:指向一个保存着共享内存的模式状态和访问权限的数据结构
返回值:
	成功返回0;失败返回-1

shmctl 函数cmd参数表

cmd 说明
IPC_STAT 将shmid_ds结构中的数据设置为共享内存的当前关联值
IPC_SET 在进程有足够的权限的前提下,把共享内存的当前关联值设置为shmid_ds结构中给出的值
IPC_RMID 删除共享内存段

代码示例

writeshm.c

#include 
#include 
#include 
#include 
#define shm_key 123 //共享内存名称

int main()
{
	//创建一个共享内存
	int shmid=shmget(shm_key,1024,IPC_CREAT |0644 );
	printf("shmid=%d\n",shmid);
	if(shmid<0)
	{
		return 0;
	}
	//将进程附加到共享内存
	struct shmid_ds buf;
	shmctl(shmid,IPC_STAT,&buf);
	printf("shm_size: %ld\n",buf.shm_segsz);
	void *lp = shmat(shmid,NULL,0);
	if(!lp)
	{
		return 0;
	}
	while(1)
	{
		sprintf((char *)lp,"%s","what your name?\n");
		sleep(1);
	}
	//分离进程与共享内存
	shmdt(lp);
	shmctl(shmid,IPC_RMID,&buf);
	return 0;
}

readshm.c

#include 
#include 
#include 
#include 
#define shm_key 123

int main()
{
	//创建一个共享内存
	int shmid=shmget(shm_key,1024,IPC_CREAT |0644 );
	if(shmid<0)
	{
		return 0;
	}
	//将进程附加到共享内存
	struct shmid_ds buf;
	shmctl(shmid,IPC_STAT,&buf);
	printf("shm_size: %ld\n",buf.shm_segsz);
	void *lp = shmat(shmid,NULL,0);
	if(!lp)
	{
		return 0;
	}
	while(1)
	{
		printf("%s\n",(char *)lp);
		sleep(1);
	}
	//分离进程与共享内存
	shmdt(lp);
	//共享内存的销毁
	shmctl(shmid,IPC_RMID,&buf);
	return 0;
}

运行结果

writeshm.c运行结果
linux——进程间通信(共享内存)_第2张图片
readshm.c运行结果
linux——进程间通信(共享内存)_第3张图片

你可能感兴趣的:(小项目)