当前位置: 首页 > news >正文

【Linux篇】进程间通信:进程IPC

目录

共享内存空间

共享内存是在用户空间还是内核空间?——用户空间

共享内存的生命周期

如何使用共享内存

共享内存的权限

共享内存是进程间通信中,速度最快的方式:

共享内存的缺点:


进程间通信标准:

  1. system V---共享内存
  2. linux内核支持了这种标准,专门设计了一个IPC通信模块,对于我们来说就是通信接口的设计

共享内存空间

共享内存是一种进程间通信的机制,即不同进程的虚拟内存空间(虚拟内存地址不需要相同),映射到相同的物理内存中。如果某个进程向共享内存写入数据,所做的改动将【立即影响到】【同时访问】(加了锁的就不算“同时可以访问")同一段共享内存的任何其他进程

在Linux中,每个进程都有属于自己的进程控制块(PCB)和地址空间(Addr Space),并且都有一个与之对应的页表,负责将进程的虚拟地址与物理地址进行映射,通过内存管理单元(MMU)进行管理。两个不同的虚拟地址通过页表映射到物理空间的同一区域,它们所指向的这块区域即共享内存

我们把将物理内存中的某段空间映射到多个进程的虚拟地址空间中的这种通信方式,叫做“共享内存”

在操作系统内,有多个共享内存同时存在,所以操作系统要将它们都管理起来

  • 先描述再组织

  • 共享内存一定会有对应的描述共享内存的内核结构。有这一点后,再加上物理内存。

  • 进程与共享内存的关系就是内核数据结构之间的关系。进程的内核数据结构与共享内存的数据结构

在共享内存中,存在引用计数,当引用计数为0时,表示没有进程在使用这块共享内存,此时就会被操作系统释放掉

共享内存是在用户空间还是内核空间?——用户空间

共享内存的接口,system V的特性

key:用来标识共享内存的唯一性

size:共享内存的大小

shmflg:共享内存创建的选项

怎么评估共享内存存在还是不存在?

怎么保证两个不同的进程,拿到的就是同一个内存?

  • 手动构建key

  • 查看一个已经创建的共享内存

ipcs -m

  • 删除共享内存

ipcrm -m +共享内存id

能不能使用key来代替id?

不能。为什么?

key是要给内核进行区分唯一性的。用户使用指令管理共享内存是在用户层的,而指令内部是对系统调用进行了封装的。也就是说,指令是运行在用户层的,而key是给OS用的,所以不能使用key来代替id

  • 代码删除共享内存

 void Destroy(){if(_shmid == gdefaultid)return;int n=shmctl(_shmid,IPC_RMID,nullptr);if(n > 0){printf("shmctl delete shm: %d success!\n",_shmid);}else{EXR_EXIT("shmctl\n");}}   

共享内存的生命周期

  • 共享内存的生命周期随内核。

  • 如果进程没有显示的删除对应的共享内存,即便进程退出了,ipc资源依旧被占用

如何使用共享内存

使用共享内存需要先把共享内存映射到进程的地址空间当中。

怎么映射的?

操作系统提供了一个系统调用shmat。调用这个系统调用的进程会把自己的堆栈之间的映射区和队友的共享内存建立映射。

成功:返回共享内存起始的虚拟地址

失败:-1

shmat,将共享内存挂接到进程的地址空间中

共享内存的权限

共享区属于用户空间

共享内存是进程间通信中,速度最快的方式:

  1. 两个进程都映射了这块空间,映射之后读写直接被对方看到

  2. 不需要进行系统调用进行读取或者写入内容,直接以指针地址的方式访问空间

共享内存的缺点:

  1. 通信双方没有所谓的同步机制

  2. 因为没有同步机制,所以会导致数据不一致

共享内存没有保护机制

如果非得将共享内存保护起来呢?

http://www.dtcms.com/a/301963.html

相关文章:

  • 搜索引擎高级搜索指令大全(Google、百度等浏览器通用)
  • R语言简介(附电子书资料)
  • 【kafka】消息队列
  • 深入Go并发编程:Channel、Goroutine与Select的协同艺术
  • Java BigDecimal详解:小数精确计算、使用方法与常见问题解决方案
  • 生产力效能跃升 金士顿DDR5 5600内存
  • 【正序拆解整数】2022-9-18
  • 二、Linux文本处理与文件操作核心命令
  • 群晖Synology Drive:打造高效安全的私有云协作平台
  • 【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts) 视频教程 - 微博文章数据可视化分析-点赞区间实现
  • 持续集成CI与自动化测试
  • 越野新王豹 5:以极致可靠性诠释“安全是最大的豪华”
  • 【免费可用】【提供源代码】对YOLOV11模型进行剪枝和蒸馏
  • Excel常用函数大全,非常实用
  • 重构vite.config.json
  • Jenkins vs GitLab CI/CD vs GitHub Actions在容器化部署流水线中的对比分析与实践指南
  • 云原生MySQL Operator开发实战(三):高级特性与生产就绪功能
  • CodeBuddy的安装教程
  • 优测推出HarmonyOS全场景测试服务,解锁分布式场景应用卓越品质!
  • 表征学习:机器认知世界的核心能力与前沿突破
  • 「源力觉醒 创作者计划」_文心大模型4.5系列开源模型,意味着什么?对开发者、对行业生态有何影响?
  • 新能源行业B端极简设计:碳中和目标下的交互轻量化实践
  • C#与C++交互开发系列(二十六):构建跨语言共享缓存,实现键值对读写与数据同步(实践方案)
  • 电子电路原理学习笔记---第4章二极管电路---第3天
  • 墨者:SQL注入实战-MySQL
  • uni-datetime-picker兼容ios
  • 【iOS】类和分类的加载过程
  • MySQL有哪些“饮鸩止渴”提高性能的方法?
  • 【Linux篇章】穿越数据迷雾:HTTPS构筑网络安全的量子级护盾,重塑数字信任帝国!
  • 全面解析MySQL(4)——三大范式与联合查询实例教程