共享内存

一、概念

系统上的每个进程都有4G的虚拟地址空间,二真实的物理空间都是独立的在物理内存上找一块空间,使得多个进程可以访问这块空间,这就是共享内存。
进程共享一个内存,如图:
在这里插入图片描述
1、创建内核对象,并且申请物理内存;

2、各进程中,分别将自己的虚拟地址通过内核对象映射到开辟的物理内存上;

3、分别访问这块内存,通过各自的指针ptra、ptrb;

4、断开链接,将虚拟地址与物理内存断开联系;

5、删除内核对象。

二、具体操作

共享内存对于多进程就是一块临界资源,多进程使用共享内存就必须做到同步控制->信号量

四个函数具体声明如下:
1、shmget函数:创建共享内存

#include<sys/shm.h>
int shmget((key_t)key,int size,int flag);
//第一个key值随意定义
//size:是申请共享内存空间的大小
//flag:权限

失败返回-1,成功返回标识符shmid。

2、shmat函数:第一次创建共享内存时,它不被任何进程访问,要想启动对这块内存的访问,必须将链接到一个进程的地址空间中,这项工作有shmat完成。

void *shmat(int shmid,const void *addr,int flag);
//第一个参数就是shmget返回的标识符
//第二个参数为共享内存连接到当前进程中的地址,可以自己给定,一般都是NULL让系统自己选择最适合的。
//第三个参数就是宏,可以SHM_RDONLY表示只读。也可以写0表示默认的可读可写。

失败返回-1 成功返回指向共享内存第一个字节的指针。

3、shmdt函数:将共享内存从当前进程中分离。

int shmdt(void *addr);
//参数为shmat中返回的指针

失败返回-1,成功返回0。

4、shmctl函数

int shmctl(int shmid,int cmd,struct shmid_ds *buff);
//第二个参数取IPC_RMID;
//第三个参数一般为0

使用共享内存的优缺点

1、优点:我们可以看到使用共享内存进行进程间的通信真的是非常方便,而且函数的接口也简单,数据的共享还使进程间的数据不用传送,而是直接访问内存,也加快了程序的效率。同时,它也不像无名管道那样要求通信的进程有一定的父子关系。

2、缺点:共享内存没有提供同步的机制,这使得我们在使用共享内存进行进程间通信时,往往要借助其他的手段来进行进程间的同步工作。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值