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

【Linux篇】补充:消息队列和systemV信号量

消息队列

消息队列和共享内存都属于system V标准

创建消息队列:

system V信号量

铺垫:

共享内存:

让两个进程看到同一份资源来实现通信:

  • 让两个进程看到同一份资源这是提供了通信前提

  • 如果共享内存没有保护机制,会导致数据不一致

数据不一致的解决方案

  • 信号量

保护机制保护的是谁?或者说约束的是谁?

  • 临界区代码
  • 保护临界区代码就是变相的保护临界资源

什么是临界区?

其实就是访问共享内存的代码段,这部分就是临界区

为什么会数据不一致?

  • 存在没有被保护的共享资源

  • 各自的代码,访问了这个没有被保护的公共资源

  1. 多个执行流(进程)能看到的同一份公共资源:共享资源

  2. 被保护起来的共享资源叫做“临界资源

  3. 在进程中,涉及到互斥资源的程序段叫做临界区---即访问该资源的代码段

  4. 多个执行流访问资源时,具有一定顺序性,叫做同步

什么是互斥

任何时刻,只允许一个执行流访问资源,叫做互斥

在申请锁的时候,必须是原子的

没当一个执行流进入临界区时,就会申请锁,这说明锁本身也是共享的

那么谁来保证锁的安全?

  • 申请锁的时候,必须是原子的

对共享资源进行保护实际上是对访问共享资源的代码进行保护

原子性是什么?

  • 要么做,要么不做

信号灯,本质是一个计数器,用来表明临界资源中,资源数量的多少

http://www.lryc.cn/news/603711.html

相关文章:

  • 从本地 Docker 部署的 Dify 中导出知识库内容(1.6版本亲测有效)
  • 数分思维12:SQL技巧与分析方法
  • 主数据管理系统能代替数据中台吗?
  • stm32开发 -- RC522模块与AS608模块相关
  • RHCE综合项目:分布式LNMP私有博客服务部署
  • 远程Qt Creator中文输入解决方案
  • Django模型开发:模型字段、元数据与继承全方位讲解
  • 如何在Linux系统下进行C语言程序的编写和debug测试
  • Apache Ignite 关于 容错(Fault Tolerance)的核心机制
  • 城市元宇宙:未来城市治理的革新路径
  • Apache Ignite 的服务(Services)功能
  • X509Certificate2.GetNameInfo(X509NameType.UrlName, false)
  • 为什么分类任务偏爱交叉熵?MSE 为何折戟?
  • 《零基础入门AI:传统机器学习入门(从理论到Scikit-Learn实践)》
  • 设计模式---单例
  • 电子界桩是什么?主要工作原理和应用领域
  • spring data mongodb 入门使用手册
  • COPRAS(Complex Proportional Assessment)简介与简单示例
  • 操作系统-lecture2(操作系统结构)
  • Qt|槽函数耗时操作阻塞主界面问题
  • 安卓逆向2-安卓刷机和获取root权限和安装LSPosed框架
  • iPhone 神级功能,3D Touch 回归!!!
  • Qt模型/视图结构
  • 信息技术发展与区块链的崛起:深度解析与未来展望
  • 搭建一个自定义的 React 图标库
  • 大模型加速的几种attention总结
  • PostgreSQL 中 date_trunc 为什么能走索引?【待验证】
  • docker安装powerdns pdnsadmin,pdns-recursor实现内网dns解析
  • 详细说明零拷贝
  • 【git】误操作后怎么解决