news 2026/4/18 7:42:26

进程同步与死锁

作者头像

张小明

前端开发工程师

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/4/16 17:11:12

基于PyTorch安装gpt-oss-20b并实现GPU算力高效调度

基于PyTorch部署gpt-oss-20b并实现GPU算力高效调度 在消费级显卡上运行一个参数量达210亿的大模型,听起来像是天方夜谭?但随着稀疏激活、量化压缩和智能设备映射等技术的成熟,这正逐渐成为现实。像 gpt-oss-20b 这类经过深度优化的开源模型&a…

作者头像 李华
网站建设 2026/4/18 5:44:28

登录架构设计

ps: 内含 分库分表 窗口限流 验证码校验 密码加密 jwt加密 等,算是一个合格的架构,我基本都是按照这个方法,生成的。哪怕是单体也是。主要是方便 登录设计 管理员登录 1.怎么实现登录安全的 2.获取短信验证码时间窗口使用了什么限流算法 登录…

作者头像 李华
网站建设 2026/4/17 18:26:26

介观交通流仿真软件:Aimsun Next_(1).介观交通流仿真的基础理论

介观交通流仿真的基础理论 1. 介观交通流仿真的概念 介观交通流仿真是一种介于宏观交通流仿真和微观交通流仿真之间的交通仿真方法。宏观仿真关注交通流的整体行为和统计特性,而微观仿真则关注每个个体车辆的详细行为。介观仿真通过结合这两种方法的优点&#xff0c…

作者头像 李华
网站建设 2026/4/18 2:19:17

从「第 K 小」这道题,看懂二叉搜索树的灵魂

别急着写代码 ——从「第 K 小」这道题,看懂二叉搜索树的灵魂 先说一句很多人不爱听、但非常重要的话: 这道题考的不是技巧,而是你到底懂不懂二叉搜索树。 如果你真的懂 BST,这题会让你觉得—— “哦,就该这么解”。 如果你不懂,那你会: 写一堆 if else 用数组存一遍…

作者头像 李华
网站建设 2026/4/11 0:58:35

通过API调用Qwen3-14B实现外部工具集成的方法

通过API调用Qwen3-14B实现外部工具集成的方法 在企业AI落地的实践中,一个常见的困境是:模型能说会道,却“光说不做”。用户问“我的订单到哪儿了”,系统只能回答“请查看物流信息”——这显然不是智能化服务应有的样子。真正有价…

作者头像 李华