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

【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.xdnf.cn/news/16489.html

相关文章:

  • 负载均衡算法中的加权随机算法
  • kafka开启Kerberos使用方式
  • uniapp_微信小程序_根据胶囊按钮计算出的导航栏高度为什么不是44px?
  • 【Linux】Ubuntu上安装.NET 9运行时与ASP.NET Core项目部署入门
  • 复杂人流场景口罩识别漏检率↓76%:陌讯动态特征融合算法实战解析
  • 开源智能体-JoyAgent集成ollama私有化模型
  • ATF 运行时服务
  • 标准解读——2024 数据资产价值评估指南(正式版)【附全文阅读】
  • ICDC自动化部署方案概述
  • 7.28 错题(zz)史纲 第五章新道路
  • Qt_Gif_Creator 基于Qt的屏幕gif录制工具
  • 灵动画布:快手可灵 AI 推出的多人协作 AI 创意工作台
  • PostgreSQL日志配置全解析:从基础设置到进阶策略
  • 墨者:SQL手工注入漏洞测试(MySQL数据库-字符型)
  • LangGraph智能体(天气和新闻助手)开发与部署
  • MySQL的常用数据类型详解
  • ROS2编写一个简单的插件
  • 2025年7月一区SCI-基尔霍夫定律优化算法Kirchhoff’s law algorithm-附Matlab免费代码
  • HDFS Block与Spark的partition对比
  • 基于AFLFast的fuzz自动化漏洞挖掘(2)
  • 中型企业如何用 RUM 技术破解地理分布式用户体验难题?从指标监测到优化实操
  • 嵌入式开发学习———Linux环境下数据结构学习(四)
  • Cacti RCE漏洞复现
  • 【AlphaFold3】网络架构篇(2)|Input Embedding 对输入进行特征嵌入
  • halcon-blob
  • docker 入门,运行上传自己的首个镜像
  • 学习人工智能所需知识体系及路径详解
  • CTF-Web学习笔记:文件包含篇
  • java中一些数据结构的转换
  • ts学习3