操作系统:进程与线程(二)同步与互斥A

一战成硕

    • [2.3 同步与互斥](#2.3 同步与互斥)
      • [2.3.1 同步与互斥的基本概念](#2.3.1 同步与互斥的基本概念)
      • [2.3.2 实现临界区互斥基本方法](#2.3.2 实现临界区互斥基本方法)
      • [2.3.3 互斥锁](#2.3.3 互斥锁)
      • [2.3.4 信号量](#2.3.4 信号量)

2.3 同步与互斥

2.3.1 同步与互斥的基本概念

  1. 临界资源
    将一次仅允许一个进程使用的资源称为临界资源。
    许多物理设备均属于临界资源,如打印机,此外,还有许多变量数据等,可以被若干进程共享,也属于临界资源。
    对于临界资源的访问,必须互斥地进行,在每个进程中,访问临界资源的那段代码称为临界区,为了保证临界资源的正确使用,可把临界资源访问过程分为四个部分:
    1)进入区
    2)临界区
    3)退出区
    4)剩余区
  2. 同步
    同步亦称直接制约关系,是指为完成某种任务而建立的两个或多个进程。
  3. 互斥
    互斥也称直接制约关系。当一个进程进入临界区使用临界资源,另一个进程必须等待,当占用临界资源的进程退出临界区,另一进程才允许去访问此临界资源。
    同步机制应遵循以下准则:
    1)空闲让进
    2)忙则等待
    3)有限等待
    4)让权等待

2.3.2 实现临界区互斥基本方法

  1. 软件实现方法

    在进入设置区设置并检查一些标志来标明是否有进程在临界区,若已经有进程在临界区,则在进入区通过循环检查进行等待,进程离开临界区后,则在退出区修改标志。

    1)算法一:单标志法

    2)算法二:双标志先检查

    3)算法三:双标志法后检查

    4)算法四:Peterson`s Algorithm


  2. 硬件实现方法

    计算机提供了特殊的硬件指令,允许对一个字的内容进行检测和修正,或对两个字的内容进行交换,通过硬件支持实现临界段问题的方法称为低级方法,或称元方法。

    (1)中断屏蔽法

(2)硬件指令法


2.3.3 互斥锁

2.3.4 信号量

用户进程可以通过使用操作系统提供的一对原语来对信号量进行操作,从而很方便的实现了进程互斥,进程同步。

信号量其实就是一个变量(可以是一个整数,也可以是更复杂的记录型变量),可以用一个信号量来表示系统中某种资源的数量。

wait(S)和signal(S)原语常简称为P(S)、V(S)。

  1. 整型信号量

  2. 记录型信号量


  3. 利用信号量实现同步

  4. 利用信号量实现进程互斥

    1)分析并发关键活动,划定临界区

    2)设置互斥信号量 初值为1

  5. 利用信号量实现前驱关系

相关推荐
Freestyle Coding18 小时前
使用rust自制操作系统内核
c语言·汇编·microsoft·rust·操作系统
打鱼又晒网1 天前
Linux进程间通信——探索共享内存—— 剖析原理, 学习接口应用
linux·运维·服务器·后端·操作系统
skaiuijing3 天前
巧用二级指针
c语言·开发语言·算法·架构·操作系统
打鱼又晒网4 天前
linux进程间通信——学习与应用命名管道, 日志程序的使用与实现
linux·运维·服务器·后端·操作系统
OpenAnolis小助手5 天前
专访AMD:AMD 正式加入龙蜥社区首秀:开源协作与 AI 创新的交汇点
ai·开源·操作系统·龙蜥社区·龙蜥操作系统大会
zhangxueyi5 天前
word文档转换为PPT文档最佳方案
操作系统·文档转换
洛寒瑜5 天前
【读书笔记-《30天自制操作系统》-18】Day19
c语言·开发语言·汇编·笔记·学习·操作系统·文件读取
望获linux6 天前
Linux网络协议栈的实现
linux·服务器·arm开发·网络协议·操作系统·嵌入式操作系统
宇寒风暖6 天前
计算机操作系统之并行性与并发性笔记
学习·操作系统·并行性·并发性
CHENGlady7 天前
操作系统的分化
操作系统