news 2026/6/5 21:16:48

进程同步与死锁

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
进程同步与死锁

目录

进程同步与互斥

进程互斥的实现

进程互斥的软件实现方法

单标志法

双标志先检查

双标志后检查

Peterson算法

进程互斥的硬件实现方法

中断屏蔽方法

TestAndSet

Swap指令

互斥锁

信号量机制

用信号量机制实现进程互斥

用信号量机制实现进程同步

用信号量机制实现进程前驱关系

经典的进程同步问题

生产者消费者问题

多生产者多消费者问题

吸烟者问题

读者写者问题

哲学家进餐问题

管程

死锁

死锁的预防

死锁的避免

死锁的检测和解除


进程同步与互斥

并发性带来了异步性,有时需要通过进程同步解决这种异步。有的进程之间需要相配合地完成工作,各进程的工作推进需要遵循一定的先后顺序。

对临界资源的访问,需要互斥的进行。即同一时间段内只能允许一个进程访问该资源。

进入区和退出区是负责实现互斥的代码段。临界区是进程中访问临界资源的代码段,也可称为临界段。

进程互斥的实现

进程互斥的软件实现方法
单标志法

双标志先检查

双标志后检查

Peterson算法

进程互斥的硬件实现方法
中断屏蔽方法

TestAndSet

Swap指令

互斥锁

信号量机制

在进程同步中,让权等待是指当进程在等待进入临界区时,应主动释放处理机(CPU),将自身阻塞并加入等待队列,让其他就绪进程有机会运行。这样可以避免CPU空转,提高系统效率。

四种软件实现方式三种硬件实现方式均存在以下问题:

  • 软件实现方式:在进入临界区前,进程通常会在一个循环中反复检查条件(如标志位或锁状态),这个过程称为忙等待(Busy Waiting)。在此期间,进程持续占用CPU执行检查指令,不会主动让出CPU,因此无法实现让权等待。

  • 硬件实现方式

    • 中断屏蔽:通过关闭中断来保证互斥,但在此期间系统无法进行进程调度,当前进程独占CPU,若它不进入临界区也不释放CPU,则其他进程无法运行。

    • TS/TSL指令和Swap/XCHG指令:常用于实现自旋锁(Spinlock),进程会在循环中反复执行这些指令尝试获取锁,同样属于忙等待,不会主动释放CPU。

这些方法的共同缺陷是:进程在等待时持续占用CPU资源,而不是阻塞自己并让出CPU,因此都无法满足让权等待的要求。这会导致CPU利用率降低,尤其在多道程序系统中可能严重影响系统性能。为了克服这一问题,后来引入了信号量(Semaphore)等机制,这些机制可以在进程等待时将其阻塞并切换至其他进程,从而实现真正的让权等待。

信号量机制

用信号量机制实现进程互斥

用信号量机制实现进程同步

用信号量机制实现进程前驱关系

经典的进程同步问题

生产者消费者问题

多生产者多消费者问题

吸烟者问题

读者写者问题

哲学家进餐问题

如何防止死锁的发生呢?

①可以对哲学家进程施加一些限制条件:比如最多允许四个哲学家同时进餐。这样可以保证至少有一个哲学家是可以拿到左右两只筷子的

②要求奇数号哲学家先拿左边的筷子,然后再拿右边的筷子,而偶数号哲学家刚好相反。用这种方法可以保证如果相邻的两个奇偶号哲学家都想吃饭,那么只会有其中一个可以拿起第一只筷子,另一个会直接阻塞。这就避免了占有一支后再等待另一只的情况。

③仅当一个哲学家左右两支筷子都可用时才允许他们拿起筷子:

管程

死锁

死锁的预防

死锁的避免

死锁的检测和解除

🙃🙃🙃...

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/5 5:27:53

通信系统仿真:数字调制与解调技术_(30).误码率BER分析

误码率BER分析 误码率(Bit Error Rate, BER)是通信系统中衡量数据传输可靠性的重要指标。BER定义为接收到的比特中错误比特的比例,通常以一个很小的数值表示。在数字通信系统中,误码率的分析和测量可以帮助我们了解系统的性能&…

作者头像 李华
网站建设 2026/5/30 15:47:18

GitHub上最受欢迎的Qwen3-8B微调项目TOP5盘点

GitHub上最受欢迎的Qwen3-8B微调项目TOP5盘点 在AI模型日益“军备竞赛”的今天,千亿参数大模型固然耀眼,但真正能落地到中小企业、个人开发者甚至边缘设备上的,往往是那些性能与成本兼得的“轻量级选手”。通义千问系列中的 Qwen3-8B 正是这样…

作者头像 李华
网站建设 2026/6/3 13:56:06

数据一多就卡?别急,先把“数据入口”修好

数据一多就卡?别急,先把“数据入口”修好 ——聊聊如何构建高吞吐、低延迟的数据接入层(Kafka / Pulsar) 咱先说一句大实话: 很多系统慢,不是算不动,而是数据进得太慢、太乱。 我见过太多项目&a…

作者头像 李华
网站建设 2026/6/4 14:49:38

算法题 自除数

自除数 问题描述 自除数 是指可以被它包含的每一位数整除的正整数。 例如,128 是一个自除数,因为 128 % 1 0,128 % 2 0,128 % 8 0。 注意:自除数不允许包含 0,因为任何数除以 0 都是未定义的。 给定两个…

作者头像 李华
网站建设 2026/6/5 6:37:52

深度解析 Flutter 自定义组件封装:从基础封装到高性能复用

欢迎大家加入[开源鸿蒙跨平台开发者社区](https://openharmonycrossplatform.csdn.net),一起共建开源鸿蒙跨平台生态。在 Flutter 开发中,“组件化” 是提升开发效率、保证代码可维护性的核心抓手。原生组件虽能满足基础需求,但实际业务中&am…

作者头像 李华
网站建设 2026/6/3 1:01:47

顺序栈的入栈函数

顺序栈的知识: 参考视频 46:31-1:01:06这部分讲了栈的概念,顺序表的初始化,出栈,入栈,获取栈顶元素 https://www.bilibili.com/video/BV1tNpbekEht?t2790.6&p5 笔记: 栈和队列栈:只能…

作者头像 李华