2.2.2 进程通信

文章目录

原语

原语(Primitive)是完成特定功能的程序段,属于原子操作,无法再被拆分。

原语存放在操作系统的内核中,包含进程控制原语、进程通信原语、资源管理原语等。

进程控制原语中包含进程创建、进程撤销、进程挂起、进程激活、进程阻塞、进程唤醒原语。

进程通信

并发执行的程序可能存在同步、互斥这2种制约关系。

  • 同步:进程在某些节点上协调相互合作进程间的工作,例如等进程A完成了某项工作,进程B才能继续进行。
  • 互斥:进程互斥地使用临界资源。临界资源(CR, Critical Resource)是一次只能供一个进程使用的资源。

临界区是一段程序,用于对临界资源实施操作,有4条原则。

  • 有空则进:无进程处于临界区时,运行进程进入。
  • 无空则等:有进程在临界区时,其他需要进入临界区的进程就等着。
  • 有限等待:保证进程等待有限时间后进入临界区。
  • 让权等待:进程等待进入临界区时,应立即释放处理机。

信号量机制

信号量机制是一种有效的进程同步、互斥的工具。整型信号量是其中一种,此处对其做介绍。

  • 信号量S:S≥0,表示资源可用数。S<0,其绝对值表示阻塞队列中等待该资源的进程数。S还可以用于表示消息,S=0,表示希望的消息未产生。S≠0,表示希望的消息已产生。
  • P操作:申请一个资源,申请后S的数值变成S-1。若S≥0,进程继续执行。若S<0,进程进入阻塞状态,插入阻塞队列。
  • V操作:释放一个资源,释放后S的数值变成S+1。若S>0,进程继续执行。若S≤0,则从阻塞队列中唤醒一个进程,插入就绪队列。
相关推荐
Hello_Embed4 小时前
STM32HAL 快速入门(二十):UART 中断改进 —— 环形缓冲区解决数据丢失
笔记·stm32·单片机·学习·嵌入式软件
咸甜适中4 小时前
rust语言 (1.88) 学习笔记:客户端和服务器端同在一个项目中
笔记·学习·rust
Grassto5 小时前
RAG 从入门到放弃?丐版 demo 实战笔记(go+python)
笔记
Magnetic_h5 小时前
【iOS】设计模式复习
笔记·学习·ios·设计模式·objective-c·cocoa
周周记笔记8 小时前
学习笔记:第一个Python程序
笔记·学习
丑小鸭是白天鹅8 小时前
Kotlin协程详细笔记之切线程和挂起函数
开发语言·笔记·kotlin
潘达斯奈基~8 小时前
《大数据之路1》笔记2:数据模型
大数据·笔记
..过云雨9 小时前
05.【Linux系统编程】进程(冯诺依曼体系结构、进程概念、进程状态(注意僵尸和孤儿)、进程优先级、进程切换和调度)
linux·笔记·学习
咸甜适中9 小时前
rust语言 (1.88) egui (0.32.2) 学习笔记(逐行注释)(二十八)使用图片控件显示图片
笔记·学习·rust·egui
一又四分之一.9 小时前
高数基础知识(下)②
笔记