news 2026/6/10 0:52:34

进程同步与死锁

作者头像

张小明

前端开发工程师

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/9 7:17:44

PyTorch-CUDA基础镜像内置TensorBoard,轻松实现训练可视化

PyTorch-CUDA 基础镜像集成 TensorBoard:让训练可视化真正“开箱即用” 在现代深度学习研发中,一个常被忽视但至关重要的问题浮出水面:我们花了几小时调通模型结构和数据流,却因为少装了一个 tensorboard 包而卡在最后一步的可视化…

作者头像 李华
网站建设 2026/6/9 14:35:02

使用Maven下载依赖构建Java后端服务对接FLUX.1-dev API

使用Maven下载依赖构建Java后端服务对接FLUX.1-dev API 在当今AI生成内容(AIGC)爆发式增长的背景下,越来越多企业希望将文生图能力快速集成到现有系统中。比如一家数字营销公司需要为广告活动自动生成视觉素材,或者一个在线教育平…

作者头像 李华
网站建设 2026/6/6 8:05:16

10 个专科生论文降重工具,AI 写作推荐与查重率优化

10 个专科生论文降重工具,AI 写作推荐与查重率优化 论文战场上的无声战役 对于专科生而言,期末论文不仅是对知识的检验,更是一场与时间、压力和自我怀疑的较量。在论文写作过程中,许多人常常陷入“写不出来”“写不好”的困境&…

作者头像 李华
网站建设 2026/6/6 8:15:02

9 个 MBA 毕业答辩 PPT 工具推荐,AI 格式优化神器

9 个 MBA 毕业答辩 PPT 工具推荐,AI 格式优化神器 论文写作的“三座大山”:时间、重复率与效率 对于MBA学生而言,毕业答辩不仅是学术生涯的重要节点,更是对综合能力的一次全面检验。然而,从选题到撰写,再到…

作者头像 李华
网站建设 2026/6/9 18:40:29

如何在大数据数仓中搭建数据集市

一、什么是数据集市?数据集市是面向特定业务需求(如销售、财务、市场等)的小型数据仓库,通常从企业级数据仓库中抽取、转换并聚合相关数据,形成易于理解、查询性能优良的数据结构。与全局数据仓库相比,数据…

作者头像 李华