news 2026/6/15 13:40:14

进程同步与死锁

作者头像

张小明

前端开发工程师

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/10 18:25:09

Memcached stats items 命令详解

Memcached stats items 命令详解 概述 Memcached 是一款高性能的分布式内存对象缓存系统,它通过在内存中存储数据来减少对数据库的访问,从而提高应用的性能。stats items 命令是 Memcached 提供的一个用于获取缓存项统计信息的命令。本文将详细介绍该命令的用法、参数以及返…

作者头像 李华
网站建设 2026/6/3 17:54:03

关于“此电脑”的小工具,让你的Windows的瞬间不一样

今天给大家推荐两款处理“此电脑”的实用软件,感兴趣的小伙伴们赶紧保存吧! ONE MyComputerManager 最近我打开“此电脑”,发现里面有三个网盘的快捷方式,简直让我这个有点强迫症的人受不了。 因此,我找到了今天要推…

作者头像 李华
网站建设 2026/6/15 12:37:26

企业估值中的AI驱动的自动化科学文献综述平台评估

企业估值中的AI驱动的自动化科学文献综述平台评估 关键词:企业估值、AI驱动、自动化科学文献综述平台、评估指标、应用场景 摘要:本文聚焦于企业估值领域中AI驱动的自动化科学文献综述平台的评估。首先介绍了研究的背景,包括目的、预期读者、…

作者头像 李华
网站建设 2026/6/10 3:58:51

Python安装新选择:Miniconda + 清华源极速配置AI开发环境

Python安装新选择:Miniconda 清华源极速配置AI开发环境 在人工智能项目日益复杂的今天,一个常见的场景是:你刚从GitHub上克隆了一个热门的深度学习项目,满怀期待地运行 pip install -r requirements.txt,结果却卡在某…

作者头像 李华
网站建设 2026/6/14 19:59:33

写给生产环境的 MySQL 高级用法:性能、兼容与真实踩坑

这 10 个 MySQL 高级用法,能让你的 SQL 更高效、更优雅 在日常开发中,很多 MySQL 查询**“能跑就行”,但在数据量变大、逻辑变复杂后,SQL 的可读性、性能和可维护性**就会迅速成为瓶颈。 本文结合真实业务场景,总结 10 个 MySQL 高级用法,不仅能显著提升查询效率,还能…

作者头像 李华
网站建设 2026/6/12 5:57:35

从“价值对齐”到“价值共生”:AI元人文构想的范式革命与路径探索

从“价值对齐”到“价值共生”:AI元人文构想的范式革命与路径探索核心立场:拥抱以数值透明表征价值,反对以数值暗地优化价值。引言:智能时代的价值绝境与范式突围我们正站在智能时代的断层线上。人工智能,特别是大型语…

作者头像 李华