操作系统学习笔记
2.4 死锁
在学习本节时,请读者思考以下问题:
1)为什么会产生死锁?产生死锁有什么条件?
2)有什么办法可以解决死锁问题?
学完本节,读者应了解死锁的由来、产生条件及基本解决方法,区分避免死锁和预防死锁。
2.4.1 死锁的概念
1. 死锁的定义
在多道程序系统中,由于进程的并发执行,极大提升了系统效率。然而,多个进程的并发执行也带来了新的问题 —— 死锁。所谓死锁,是指多个进程因竞争资源而造成的一种僵局(互相等待对方手里的资源),使得各个进程都被阻塞,若无外力干涉,这些进程都无法向前推进。
下面通过一些实例来说明死锁现象。
先看生活中的一个实例。在一条河上有一座桥,桥面很窄,只能容纳一辆汽车通行。若有两辆汽车分别从桥的左右两端驶上该桥,则会出现下述冲突情况:此时,左边的汽车占有桥面左边的一段,右边的汽车占有桥面右边的一段,要想过桥则需等待左边或右边的汽车向后行驶以退出桥面。但若左右两边的汽车都只想向前行驶,则两辆汽车都无法过桥。
在计算机系统中也存在类似的情况。例如,某计算机系统中只有一台打印机和一台输入设备,进程 P1正占用输入设备,同时又提出使用打印机的请求,但此时打印机正被进程 P2 所占用,而 P2 在未释放打印机之前,又提出请求使用正被 P1 占用的输入设备。这样,两个进程相互无休止地等待下去,均无法继续向前推进,此时两个进程陷入死锁状态。
2. 死锁与饥饿
一组进程处于死锁状态是指组内的每个进程都在等待一个事件,而该事件只可能由组内的另一个进程产生。与死锁相关的另一个问题是饥饿,即进程在信号量内无穷等待的情况。
产生饥饿的主要原因是:当系统中有多个进程同时申请某类资源时,由分配策略确定资源分配给进程的次序,有的分配策略可能是不公平的,即不能保证等待时间上界的存在。在这种情况下,即使系统未发生死锁,某些进程也可能长时间等待。当等待时间给进程的推进带来明显影响时,称发生了饥饿。例如,当有多个进程需要打印文件时,若系统分配打印机的策略是最短文件优先,则长文件的打印任务将因短文件的源源不断到来而被无限期推迟,最终导致饥饿,甚至“饿死”。饥饿并不表示系统一定会死锁,但至少有一个进程的执行被无限期推迟。
死锁和饥饿的共同点都是进程无法顺利向前推进的现象。
死锁和饥饿的主要差别:
①发生饥饿的进程可以只有一个;而死锁是因循环等待对方手里的资源而导致的,因此,若有死锁现象,则发生死锁的进程必然大于或等于两个。
②发生饥饿的进程可能处于就绪态(长期得不到CPU,如SJF算法的问题),也可能处于阻塞态(如长期得不到所需的I/O设备,如上述举例);而发生死锁的进程必定处于阻塞态。
3. 死锁产生的原因
**命题追踪** 单类资源竞争时发生死锁的临界条件的分析(2009、2014)
(1)系统资源的竞争
通常系统中拥有的不可剥夺资源(如磁带机、打印机等),其数量不足以满足多个进程运行的需要,使得进程在运行过程中,会因争夺资源而陷入僵局。只有对不可剥夺资源的竞争才可能产生死锁,对可剥夺资源(如CPU和主存)的竞争是不会引起死锁的。
(2)进程推进顺序非法
请求和释放资源的顺序不当,也同样会导致死锁。例如,进程 P1,P2 分别保持了资源 R1,R2,而 P1申请资源 R2、P2 申请资源 R1时,两者都会因为所需资源被占用而阻塞,于是导致死锁。
信号量使用不当也会造成死锁。进程间彼此相互等待对方发来的消息,也会使得这些进程无法继续向前推进。例如,进程A等待进程B发的消息,进程B又在等待进程A发的消息,可以看出进程A和B不是因为竞争同一资源,而是在等待对方的资源导致死锁。
4. 死锁产生的必要条件
产生死锁必须同时满足以下4个条件,只要其中任一条件不成立,死锁就不会发生。
1)互斥条件。进程要求对所分配的资源(如打印机)进行排他性使用,即在一段时间内某资源仅为一个进程所占有。此时若有其他进程请求该资源,则请求进程只能等待。
2)不可剥夺条件。进程所获得的资源在未使用完之前,不能被其他进程强行夺走,即只能由获得该资源的进程自己来释放(只能是主动释放)。
3)请求并保持条件。进程已经保持了至少一个资源,但又提出了新的资源请求,而该资源已被其他进程占有,此时请求进程被阻塞,但对自己已获得的资源保持不放。
资源分配图含圈而系统又不一定有死锁的原因是,同类资源数大于1。但若系统中每类资源都只有一个资源,则资源分配图含圈就变成了系统出现死锁的充分必要条件。
要注意区分不可剥夺条件与请求并保持条件。下面用一个简单的例子进行说明:若你手上拿着一个苹果(即便你不打算吃),别人不能将你手上的苹果拿走,则这就是不可剥夺条件;若你左手拿着一个苹果,允许你右手再去拿一个苹果,则这就是请求并保持条件。
01. 下列情况中,可能导致死锁的是( )。
A. 进程释放资源
B. 一个进程进入死循环
C. 多个进程竞争资源出现了循环等待
D. 多个进程竞争使用共享型设备
01.C
引起死锁的 4 个必要条件是:互斥、占有并等待、非剥夺和循环等待。本题中,出现了循环等待的现象,意味着可能导致死锁。进程释放资源不会导致死锁,进程自己进入死循环只能产生 “饥饿”,不涉及其他进程。共享型设备允许多个进程申请使用,因此不会造成死锁。再次提醒,死锁一定要有两个或两个以上的进程才会导致,而饥饿可能由一个进程导致。
5. 死锁的处理策略
为使系统不发生死锁,必须设法破坏产生死锁的4个必要条件之一,或允许死锁产生,但当死锁发生时能检测出死锁,并有能力实现恢复。
1)死锁预防。设置某些限制条件,破坏产生死锁的4个必要条件中的一个或几个。
2)避免死锁。在资源的动态分配过程中,用某种方法防止系统进入不安全状态。
3)死锁的检测及解除。无须采取任何限制性措施,允许进程在运行过程中发生死锁。通过系统的检测机构及时地检测出死锁的发生,然后采取某种措施解除死锁。
预防死锁和避免死锁都属于事先预防策略,预防死锁的限制条件比较严格,实现起来较为简单,但往往导致系统的效率低,资源利用率低;避免死锁的限制条件相对宽松,资源分配后需要通过算法来判断是否进入不安全状态,实现起来较为复杂。
死锁的几种处理策略的比较见表2.5。
2.4.2 死锁预防
**命题追踪** 死锁预防的特点(2019)
预防死锁的发生只需破坏死锁产生的4个必要条件之一即可。
1. 破坏互斥条件
若将只能互斥使用的资源改造为允许共享使用,则系统不会进入死锁状态。但有些资源根本不能同时访问,如打印机等临界资源只能互斥使用。所以,破坏互斥条件而预防死锁的方法不太可行,而且为了系统安全,很多时候还必须保护这种互斥性。
2. 破坏不可剥夺条件
当一个已经保持了某些不可剥夺资源的进程,请求新的资源而得不到满足时,它必须释放已经保持的所有资源,待以后需要时再重新申请。这意味着,进程已占有的资源会被暂时释放,或者说是被剥夺了,从而破坏了不可剥夺条件。
该策略实现起来比较复杂。释放已获得的资源可能造成前一阶段工作的失效,因此这种方法常用于状态易于保存和恢复的资源,如CPU的寄存器及内存资源,一般不能用于打印机之类的资源。反复地申请和释放资源既影响进程推进速度,又增加系统开销,进而降低了系统吞吐量。
3. 破坏请求并保持条件
要求进程在请求资源时不能持有不可剥夺资源,可以通过两种方法实现:
1)采用预先静态分配方法,即进程在运行前一次申请完它所需要的全部资源。在它的资源未满足前,不让它投入运行。在进程的运行期间,不会再提出资源请求,从而破坏了“请求”条件。在等待期间,进程不占有任何资源,从而破坏了“保持”条件。
2)允许进程只获得运行初期所需的资源后,便可开始运行。进程在运行过程中再逐步释放已分配给自己且已使用完毕的全部资源后,才能请求新的资源。
方法一的实现简单,但缺点也显而易见,系统资源被严重浪费,其中有些资源可能仅在运行初期或快结束时才使用,而且会导致“饥饿”现象,由于个别资源长期被其他进程占用,将导致等待该资源的进程迟迟不能开始运行。方法二则改进了这些缺点。
4. 破坏循环等待条件
为了破坏循环等待条件,可以采用顺序资源分配法。首先给系统中的各类资源编号,规定每个进程必须按编号递增的顺序请求资源,同类资源(编号相同的资源)一次申请完。也就是说,一个进程只在已经占有小编号的资源时,才有资格申请更大编号的资源。按此规则,已持有大编号资源的进程不可能再逆向申请小编号的资源,因此不会产生循环等待的现象。
这种方法的缺点:编号必须相对稳定,因此不便于增加新类型设备;尽管在编号时已考虑到大多数进程使用这些资源的顺序,但是进程实际使用资源的顺序还是可能和编号的次序不一致,这就会造成资源的浪费;此外,必须按规定次序申请资源,也会给用户编程带来麻烦。
2.4.3 死锁避免
避免死锁同样属于事先预防策略,但并不是事先采取某种限制措施破坏死锁的必要条件,而是在每次分配资源的过程中,都要分析此次分配是否会带来死锁风险,只有在不产生死锁的情况下,系统才会为其分配资源。这种方法所施加的限制条件较弱,可以获得较好的系统性能。
1. 系统安全状态
避免死锁的方法中,允许进程动态地申请资源,但系统在进行资源分配之前,应先计算此次
分配的安全性。若此次分配不会导致系统进入不安全状态,则允许分配;否则让进程等待。
所谓安全状态,是指系统能按某种进程推进顺序(P1,P2,…,Pn)为每个进程Pi分配其所需的资源,直至满足每个进程对资源的最大需求,使每个进程都可顺利完成。此时称P1,P2,…,Pn为安全序列(可能有多个)。若系统无法找到一个安全序列,则称系统处于不安全状态。
**命题追踪** 系统安全状态的分析(2018)
假设系统有三个进程P1,P2和P3,共有12台磁带机。P1需要10台,P2和P3分别需要4台和9台。假设在T0时刻,P1,P2和P3已分别获得5台、2台和2台,尚有3台未分配,见表2.6。
在T0时刻是安全的,因为存在一个安全序列P2,P1,P3,只要系统按此进程序列分配资源,那么每个进程都能顺利完成。也就是说,当前可用资源数为3,先将2台分配给P2以满足其最大需求,P2结束并归还资源后,系统有5台可用;接下来给P1分配5台以满足其最大需求,P1结束并归还资源后,剩余10台可用;最后分配7台给P3,这样P3也能顺利完成。
若在T0时刻后,系统分配1台给P3,剩余可用资源数为2,此时系统进入不安全状态,因为此时已无法再找到一个安全序列。当系统进入不安全状态后,便可能导致死锁。例如,将剩下的2台分配给P2,这样,P2完成后只能释放4台,既不能满足P1又不能满足P3,致使它们都无法推进到完成,彼此都在等待对方释放资源,陷入僵局,即导致死锁。
若系统处于安全状态,则一定不会发生死锁;若系统进入不安全状态,则有可能发生死锁(处于不安全状态未必就会发生死锁,但发生死锁时一定是处于不安全状态)。
2. 银行家算法
**命题追踪** 银行家算法的特点(2013、2019)
银行家算法是最著名的死锁避免算法,其思想是:将操作系统视为银行家,操作系统管理的资源视为银行家管理的资金,进程请求资源相当于用户向银行家贷款。进程运行之前先声明对各种资源的最大需求量,其数量不应超过系统的资源总量。当进程在运行中申请资源时,系统必须先确定是否有足够的资源分配给该进程。若有,再进一步试探在将这些资源分配给进程后,是否会使系统处于不安全状态。若不会,则将资源分配给它,否则让进程等待。
2.4.4 死锁检测和解除
**命题追踪** 死锁避免和死锁检测的区分(2015)
前面介绍的死锁预防和避免算法,都是在为进程分配资源时施加限制条件或进行检测,若系统为进程分配资源时不采取任何预防或避免措施,则应该提供死锁检测和解除的手段。
1. 死锁检测
**命题追踪** 死锁避免和死锁检测对比(2015)
死锁避免和死锁检测的对比。死锁避免需要在进程的运行过程中一直保证之后不可能出现死锁,因此需要知道进程从开始到结束的所有资源请求。而死锁检测是检测某个时刻是否发生死锁,不需要知道进程在整个生命周期中的资源请求,只需知道对应时刻的资源请求。
**命题追踪** 多在资源竞争时发生死锁的临界条件分析(2016、2021)
可用资源分配图来检测系统所处的状态是否为死锁状态。如图2.15(a)所示,用圆圈表示一个进程,用框表示一类资源。一种类型的资源可能有多个,因此用框中的一个圆表示一类资源中的一个资源。从进程到资源的有向边称为请求边,表示该进程申请一个单位的该类资源;从资源到进程的有向边称为分配边,表示该类资源已有一个资源分配给了该进程。
在图2.15(a)所示的资源分配图中,进程P1已分得了两个R1资源,并又请求一个R2资源;进程P2分得了一个R1资源和一个R2资源,并又请求一个R1资源。
简化资源分配图可检测系统状态S是否为死锁状态。简化方法如下:
1)在资源分配图中,找出既不阻塞又不孤立的进程Pi(找出一条有向边与它相连,且该有向边对应资源的申请数量小于或等于系统中已有的空闲资源数量,如在图2.15(a)中,R1没有空闲资源,R2有一个空闲资源。若所有连接该进程的边均满足上述条件,则这个进程能继续运行直至完成,然后释放它所占有的所有资源)。消去它所有的请求边和分配边,使之成为孤立的节点。在图2.15(a)中,P1是满足这一条件的进程节点,将P1的所有边消去,便得到图2.15(b)所示的情况。 这里要注意一个问题,判断某种资源是否有空闲,应该用它的资源数量减去它在资源分配图中的出度,例如在图2.15(a)中,R1的资源数为3,而出度也为3,所以R1没有空闲资源,R2的资源数为2,出度为1,所以R2有一个空闲资源。
2)进程Pi所释放的资源,可以唤醒某些因等待这些资源而阻塞的进程,原来的阻塞进程可能变为非阻塞进程。在图2.15(a)中,$P_2$就满足这样的条件。根据1)中的方法进行一系列简化后,若能消去图中所有的边,则称该图是可完全简化的,如图2.15(c)所示。
S为死锁的条件是当且仅当S状态的资源分配图是不可完全简化的,该条件为死锁定理。
2. 死锁解除
**命题追踪** 解除死锁的方式(2019)
一旦检测出死锁,就应立即采取相应的措施来解除死锁。死锁解除的主要方法有:
1)资源剥夺法。挂起某些死锁进程,并抢占它的资源,将这些资源分配给其他的死锁进程。但应防止被挂起的进程长时间得不到资源而处于资源匮乏的状态。
**注意** 在资源分配图中,用死锁定理化简后,还有边相连的那些进程就是死锁进程。
2)撤销进程法。强制撤销部分、甚至全部死锁进程,并剥夺这些进程的资源。撤销的原则可以按进程优先级和撤销进程代价的高低进行。这种方式实现简单,但付出的代价可能很大,因为有些进程可能已经接近结束,一旦被终止,以后还得从头再来。
3)进程回退法。让一个或多个死锁进程回退到足以回避死锁的地步,进程回退时自愿释放资源而非被剥夺。要求系统保持进程的历史信息,设置还原点。
2.4.5 本节小结
本节开头提出的问题的参考答案如下。
1)为什么会产生死锁?产生死锁有什么条件?
由于系统中存在一些不可剥夺资源,当两个或两个以上的进程占有自身的资源并请求对方的资源时,会导致每个进程都无法向前推进,这就是死锁。死锁产生的必要条件有4个,分别是互斥条件、不剥夺条件、请求并保持条件和循环等待条件。
互斥条件是指进程要求分配的资源是排他性的,即最多只能同时供一个进程使用。
不剥夺条件是指进程在使用完资源之前,资源不能被强制夺走。 请求并保持条件是指进程占有自身本来拥有的资源并要求其他资源。
循环等待条件是指存在一种进程资源的循环等待链。
2)有什么办法可以解决死锁问题?
死锁的处理策略可以分为预防死锁、避免死锁及死锁的检测与解除。
死锁预防是指通过设立一些限制条件,破坏死锁的一些必要条件,让死锁无法发生。
死锁避免指在动态分配资源的过程中,用一些算法防止系统进入不安全状态,从而避免死锁。
死锁的检测和解除是指在死锁产生前不采取任何措施,只检测当前系统有没有发生死锁,若有,则采取一些措施解除死锁。
2.4.6 本节习题精选
一、单项选择题
01. 下列情况中,可能导致死锁的是( )。
A. 进程释放资源
B. 一个进程进入死循环
C. 多个进程竞争资源出现了循环等待
D. 多个进程竞争使用共享型设备
01.C
引起死锁的 4 个必要条件是:互斥、占有并等待、非剥夺和循环等待。本题中,出现了循环等待的现象,意味着可能导致死锁。进程释放资源不会导致死锁,进程自己进入死循环只能产生 “饥饿”,不涉及其他进程。共享型设备允许多个进程申请使用,因此不会造成死锁。再次提醒,死锁一定要有两个或两个以上的进程才会导致,而饥饿可能由一个进程导致。02. 在哲学家进餐问题中,若所有哲学家同时拿起左筷子,则发生死锁,因为他们都需要右筷子才能用餐。为了让尽可能多的哲学家可以同时用餐,并且不发生死锁,可以利用信号量PV操作实现同步互斥,下列说法中正确的是( )。
A. 使用信号量进行控制的方法一定可以避免死锁
B. 同时检查两支筷子是否可用的方法可以预防死锁,但是会导致饥饿问题
C. 限制允许拿起筷子的哲学家数量可以预防死锁,它破坏了“循环等待”条件
D. 对哲学家顺序编号,奇数号哲学家先拿左筷子,然后拿右筷子,而偶数号哲学家刚好相反,可以预防死锁,它破坏了“互斥”条件
02.C
信号量机制能确保临界资源的互斥访问,不能完全避免死锁,选项 A 错误。
同时检查两支筷子是否可用的方法可以预防死锁,但是会导致资源浪费,因为可能有一些空闲的筷子无法使用,但拿到筷子的哲学家用完餐后,释放筷子,其他哲学家就可以正常用餐,因此不会导致饥饿现象,选项 B 错误。
若限制允许拿起筷子的哲学家数量,则不被允许的哲学家左边的哲学家一定可以拿到两边的筷子,从而破坏 “循环等待” 条件,选项 C 正确。
对哲学家顺序编号,奇数号哲学家先拿左筷子,然后拿右筷子,而偶数号哲学家刚好相反,则相邻的哲学家总有一个可以拿起两边的筷子,但这破坏的是 “循环等待” 条件,而不是 “互斥条件” ,选项 D 错误。
03. 下列关于进程死锁的描述中,错误的是( )。
A. 若每个进程只能同时申请或拥有一个资源,则不会发生死锁
B. 若多个进程可以无冲突共享访问所有资源,则不会发生死锁
C. 若所有进程的执行严格区分优先级,则不会发生死锁
D. 若进程资源请求之间不存在循环等待,则不会发生死锁
03. C
进程的执行优先级并不能破坏死锁的四个必要条件。即使有高优先级和低优先级的进程,若它们都请求或占有了不可抢占的资源,且形成了环路等待,则死锁仍可能发生。选项 A 可以破坏请求并保持条件,选项 B 可以破坏互斥条件,选项 D 可以破坏循环等待条件。
04. 一次分配所有资源的方法可以预防死锁的发生,它破坏死锁4个必要条件中的( )。
A. 互斥
B. 占有并请求
C. 非剥夺
D. 循环等待
04. B
发生死锁的 4 个必要条件:互斥、占有并请求、非剥夺和循环等待。一次分配所有资源的方法是当进程需要资源时,一次性提出所有的请求,若请求的所有资源均满足则分配,只要有一项不满足,就不分配任何资源,该进程阻塞,直到所有的资源空闲后,满足进程的所有需求时再分配。这种分配方式不会部分地占有资源,因此打破了死锁的 4 个必要条件之一,实现了对死锁的预防。但是,这种分配方式需要凑齐所有资源,因此当一个进程所需的资源较多时,资源的利用率会较低,甚至会造成进程 “饥饿” 。
05. 系统产生死锁的可能原因是( )。
A. 独占资源分配不当
B. 系统资源不足
C. 进程运行太快
D. CPU内核太多
05. A
系统死锁的可能原因主要是时间上和空间上的。时间上由于进程运行中推进顺序不当,即调度时机不合适,不该切换进程时进行了切换,可能造成死锁;空间上的原因是对独占资源分配不当,互斥资源部分分配又不可剥夺,极易造成死锁。那么,为什么系统资源不足不是造成死锁的原因呢?系统资源不足只会对进程造成 “饥饿” 。例如,某系统只有三台打印机,若进程运行中要申请四台,显然不能满足,该进程会永远等待下去。若该进程在创建时便声明需要四台打印机,则操作系统立即就会拒绝,这实际上是资源分配不当的一种表现。不能以系统资源不足来描述剩余资源不足的情形。
06. 死锁的避免是根据( )采取措施实现的。
A. 配置足够的系统资源
B. 使进程的推进顺序合理
C. 破坏死锁的四个必要条件之一
D. 防止系统进入不安全状态
06. D
死锁避免是指在资源动态分配过程中用某些算法加以限制,防止系统进入不安全状态从而避免死锁的发生。选项 B 是避免死锁后的结果,而不是措施的原理。
07. 死锁预防是保证系统不进入死锁状态的静态策略,其解决办法是破坏产生死锁的四个必要条件之一。下列方法中破坏了“循环等待”条件的是( )。
A. 银行家算法
B. 一次性分配策略
C. 剥夺资源法
D. 资源有序分配策略
07. D
资源有序分配策略可以限制循环等待条件的发生。选项 A 判断是否为不安全状态;选项 B 破坏了占有请求条件;选项 C 破坏了非剥夺条件。
08. 可以防止系统出现死锁的手段是( )。
A. 用PV操作管理共享资源
B. 使进程互斥地使用共享资源
C. 采用资源静态分配策略
D. 定时运行死锁检测程序
08. C
选项A,PV 操作不能破坏死锁条件,反而可能加强互斥和占有并等待条件。选项 B 同理。选项 C 可以破坏请求并保持条件。选项 D 只能在系统出现死锁时检测,却不能防止系统出现死锁。
09. 某系统中有三个并发进程都需要四个同类资源,则该系统必然不会发生死锁的最少资源是( )。
A. 9
B. 10
C. 11
D. 12
09. B
资源数为 9 时,存在三个进程都占有三个资源,为死锁;资源数为 10 时,必然存在一个进程能拿到 4 个资源,然后可以顺利执行完其他进程。
10. 某系统中共有11台磁带机,X个进程共享此磁带机设备,每个进程最多请求使用3台,则系统必然不会死锁的最大X值是( )。
A. 4
B. 5
C. 6
D. 7
10. B
考虑一下极端情况:每个进程已经分配了两台磁带机,那么其中任何一个进程只要再分配一台磁带机即可满足它的最大需求,该进程总能运行下去直到结束,然后将磁带机归还给系统再次分配给其他进程使用。因此,系统中只要满足 2X + 1 = 11 这个条件即可认为系统不会死锁,解得 X = 5,也就是说,系统中最多可以并发 5 个这样的进程是不会死锁的。或者,根据死锁公式,资源数大于进程个数乘以 “每个进程需要的最大资源数减 1” 就不会发生死锁,即 m > n (w - 1),其中 m 是磁带机的数量,n 是进程的数量,w 是每个进程最多请求的磁带机数量。代入可得 11 > n (3 - 1),即 n < 5.5,n 是正整数,因此系统必然不会死锁的最大 n 值是 5。
11. 若系统中有5个某类资源供若干进程共享,则不会引起死锁的情况是( )。
A. 有6个进程,每个进程需1个资源
B. 有5个进程,每个进程需2个资源
C. 有4个进程,每个进程需3个资源
D. 有3个进程,每个进程需4个资源
11. A
A 项的每个进程只申请一个资源,破坏了请求并保持条件,必然不会发生死锁。或者,根据死锁公式,假设系统共有 m 个资源,n 个进程,每个进程需要 k 个资源,若满足 m > n (k - 1),则系统一定不会发生死锁,代入公式可知选项 B、C、D 均可能发生死锁。
12. 解除死锁通常不采用的方法是( )。
A. 终止一个死锁进程
B. 终止所有死锁进程
C. 从死锁进程处抢夺资源
D. 从非死锁进程处抢夺资源
12. D
解除死锁的方法有,①剥夺资源法:挂起某些死锁进程,并抢占它的资源,将这些资源分配给其他的死锁进程;②撤销进程法:强制撤销部分甚至全部死锁进程并剥夺这些进程的资源。
13. 采用资源剥夺法可以解除死锁,还可以采用( )方法解除死锁。
A. 执行并行操作 B. 撤销进程 C. 拒绝分配新资源 D. 修改信号量
13. B
资源剥夺法允许一个进程强行剥夺其他进程所占有的系统资源。而撤销进程强行释放一个进程已占有的系统资源,与资源剥夺法同理,都通过破坏死锁的 “请求和保持” 条件来解除死锁。拒绝分配新资源只能维持死锁的现状,无法解除死锁。
14. 在下列死锁的解决方法中,属于死锁预防策略的是( )。
A. 银行家算法 B. 资源有序分配算法 C. 死锁检测算法 D. 资源分配图化简法
14. B
其中,银行家算法为死锁避免算法,死锁检测算法和资源分配图化简法为死锁检测,根据排除法可以得出资源有序分配算法为死锁预防策略。
15. 三个进程共享四个同类资源,这些资源的分配与释放只能一次一个。已知每个进程最多需要两个该类资源,则该系统( )。
A. 有些进程可能永远得不到该类资源
B. 必然有死锁
C. 进程请求该类资源必然能得到
D. 必然是死锁
15. C
不会发生死锁。因为每个进程都分得一个资源时,还有一个资源可以让任意一个进程满足,这样这个进程可以顺利运行完成进而释放它的资源。
16. 以下有关资源分配图的描述中,正确的是( )。
A. 有向边包括指向资源类的分配边和资源类指向进程申请边两类
B. 矩形框表示进程,其中圆点表示申请同一类资源的各个进程
C. 圆圈节点表示资源类
D. 资源分配图是一个有向图,用于表示某时刻系统资源与进程之间的状态
16. D
进程指向资源的有向边称为申请边,资源指向进程的有向边称为分配边,选项 A 张冠李戴;矩形框表示资源,其中的圆点表示资源的数量,选项 B 错;圆圈节点表示进程,选项 C 错;选项 D 的说法是正确的。
17. 死锁的四个必要条件中,无法破坏的是( )。
A. 环路等待资源 B. 互斥使用资源 C. 占有且等待资源 D. 非抢夺式分配
17. B
所谓破坏互斥使用资源,是指允许多个进程同时访问资源,但有些资源根本不能同时访问,如打印机只能互斥使用。因此,破坏互斥条件而预防死锁的方法不太可行,而且在有的场合应该保护这种互斥性。其他三个条件都可以实现。
18. 死锁与安全状态的关系是( )。
A. 死锁状态有可能是安全状态
B. 安全状态有可能成为死锁状态
C. 不安全状态就是死锁状态
D. 死锁状态一定是不安全状态
18. D
如下图所示,并非所有不安全状态都是死锁状态,但当系统进入不安全状态后,便可能进入死锁状态;反之,只要系统处于安全状态,系统便可避免进入死锁状态;死锁状态必定是不安全状态。
不安全状态
死锁状态
包含死锁状态
是不安全状态的一部分
![]()
19. 死锁检测时检查的是( )。
A. 资源有向图 B. 前驱图 C. 搜索树 D. 安全图
19. A
死锁检测一般采用两种方法:资源有向图法和资源矩阵法。前驱图只是说明进程之间的同步关系,搜索树用于数据结构的分析,安全图并不存在。注意死锁避免和死锁检测的区别:死锁避免是指避免死锁发生,即死锁没有发生;死锁检测是指死锁已出现,要把它检测出来。
20. 某个系统采用下列资源分配策略。若一个进程提出资源请求得不到满足,而此时没有由于等待资源而被阻塞的进程,则自己就被阻塞。而当此时已有等待资源而被阻塞的进程,则检查所有由于等待资源而被阻塞的进程。若它们有申请进程所需要的资源,则将这些资源取出并分配给申请进程。这种分配策略会导致( )。
A. 死锁 B. 颠簸 C. 回退 D. 饥饿
20. D
某个进程主动释放资源不会导致死锁,因为破坏了请求并保持条件,选项 A 错。颠簸也就是抖动,这是请求分页系统中页面调度不当而导致的现象,是下一章讨论的问题,这里权且断定选项 B 是错的。回退是指从此时此刻的状态退回到一分钟之前的状态,假如一分钟之前拥有资源 X,它有可能释放了资源 X,那就不称回到一分钟之前的状态,也就不是回退,选项 C 错。因为进程过于 “慷慨” ,不断把自己已得到的资源送给别人,导致自己长期无法完成,所以是饥饿,选项 D 正确。
21. 系统的资源分配图在下列情况下,无法判断是否处于死锁状态的有( )。
I. 出现了环路 II. 没有环路
III. 每种资源只有一个,并出现环路 IV. 每个进程节点至少有一条请求边
A. I、II、III、IV
B. I、III、IV
C. I、IV
D. 以上答案都不正确
21. C
出现了环路,只是满足了循环等待的必要条件,而满足必要条件不一定会导致死锁,选项 I 对;没有环路,破坏了循环等待条件,一定不会发生死锁,选项 II 错;每种资源只有一个,又出现了环路,这是死锁的充分条件,可以确定是否有死锁,选项 III 错;即使每个进程至少有一条请求边,若资源足够,则不会发生死锁,但若资源不充足,则有发生死锁的可能,选项 IV 对。
综上所述,选择选项 C。22. 下列关于死锁的说法中,正确的有( )。
I. 死锁状态一定是不安全状态
II. 产生死锁的根本原因是系统资源分配不足和进程推进顺序非法
III. 资源的有序分配策略可以破坏死锁的循环等待条件
IV. 采用资源剥夺法可以解除死锁,还可以采用撤销进程方法解除死锁
A. I、III B. II C. IV D. 四个说法都对
22. D
选项 I 正确。
选项 II 正确:这是产生死锁的两大原因。
选项 III 正确:在对资源进行有序分配时,进程间不可能出现环形链,即不会出现循环等待。
选项 IV 正确:资源剥夺法允许一个进程强行剥夺其他进程占有的系统资源。而撤销进程强行释放一个进程已占有的系统资源,与资源剥夺法同理,都通过破坏死锁的 “请求和保持” 条件来解除死锁,所以选择选项 D。
23. 下面是并发进程的程序代码,正确的是( )。
A. 进程不会死锁,也不会“饥饿”
B. 进程不会死锁,但是会“饥饿”
C. 进程会死锁,但是不会“饥饿”
D. 进程会死锁,也会“饥饿”
23. B
遇到这种问题时千万不要慌张,下面我们来慢慢分析,给读者一个清晰的解题过程:
仔细考察程序代码,可以看出这是一个扩展的单行线问题。也就是说,某单行线只允许单方向的车辆通过,在单行线的入口设置信号量 y,在告示牌上显示某一时刻各方向来车的数量 c1 和 c2,用 c2 修改告示牌上的车辆数量必须互斥进行,为此设置信号量 x1 和 x2。若某方向的车辆需要通过时,则首先要将该方向来车数量 c1 或 c2 增加 1,并查看自己是否是第一个进入单行线的车辆,若是,则获取单行线的信号量 y,并进入单行线。通过此路段以后出单行线时,将该方向的车辆数 c1 或 c2 减 1(当然是利用 x1 或 x2 来互斥修改),并查看自己是否是最后一辆车,若是,则释放单行线的互斥量 y,否则保留信号量 y,让后继车辆继续通过。双方的操作如出一辙。考虑出现一个极端情况,即当某方向的车辆首先占据单行线并后来者络绎不绝时,另一个方向的车辆就再没有机会通过该单行线了。而这种现象是由于算法本身的缺陷造成的,不属于因为特殊序列造成的饥饿,所以它是真正的饥饿现象。因为有信号量的控制,所以死锁的可能性没有了(双方同时进入单行线,在中间相遇,造成双方均无法通过的情景)。①假设 P1 进程稍快,P2 进程稍慢,同时运行;②P1 进程首先进入 if 条件语句,因此获得了 y 的互斥访问权,P2 被阻塞;③在第一个 P1 进程未释放 y 之前,又有另一个 P1 进入,c1 的值变成 2,当第一个 P1 离开时,P2 仍然被阻塞,这种情形不断发生;④在这种情况下会发生什么事?P1 顺利执行,P2 很郁闷,长期被阻塞。
综上所述,不会发生死锁,但会出现饥饿现象。因此选 B。24. 有两个并发进程,对于如下这段程序的运行,正确的说法是( )。
A. 程序能正确运行,结果唯一
B. 程序不能正确运行,可能有两种结果
C. 程序不能正确运行,结果不确定
D. 程序不能正确运行,可能死锁
24. C
本题中两个进程不能正确地工作,运行结果的可能性详见下面的说明。
不确定的原因是由于使用了公共变量 x,考查与变量 x 有关的语句共四处,执行的顺序是 1→2→3→4→5→6→7→8 时,结果是 y = 1, z = 1, t = 2, u = 2, x = 0;并发执行过程是 1→2→5→6→3→4→7→8 时,结果是 y = 0, z = 0, t = 2, u = 2, x = 0;执行的顺序是 5→6→7→8 →1→2→3→4 时,结果是 y = 1, z = 1, t = 2, u = 2, x = 1;执行的顺序是 5→6→1→ 2→7→8→3→4 时,结果是 y = 1, z = 1, t = 2, u = 2, x = 1。可见结果有多种可能性。
显然,无论执行顺序如何,x 的结果只能是 0 或 1,因此语句 7 的条件一定成立,即 t = u = 2 的结果是一定的;而 y = z 必定成立,只可能有 0, 1 两种情况,又不可能出现 x = 1, y = z = 0 的情况,所以总共有 3 种结果(答案中的 3 种)。25. 一个进程在获得资源后,只能在使用完资源后由自己释放,这属于死锁必要条件的( )。
A. 互斥条件 B. 请求和释放条件 C. 不剥夺条件 D. 防止系统进入不安全状态
25. C
一个进程在获得资源后,只能在使用完资源后由自己释放,即它的资源不能被系统剥夺,答案为选项 C。
26. 假设具有5个进程的进程集合P = {P₀, P₁, P₂, P₃, P₄},系统中有三类资源A, B, C,假设在某时刻有如下状态,见下表。
系统是处于安全状态的,则x, y, z的取值可能是( )。
I. 1, 4, 0
II. 0, 6, 2
III. 1, 1, 1
IV. 0, 4, 7
A. I、II、IV B. I、II C. 仅I D. I、III
26. C
选项 I:根据 need 矩阵可知,当 Available 为 (1, 4, 0) 时,可满足 P2 的需求;P2 结束后释放资源,Available 为 (2, 7, 5) 可以满足 P0, P1, P3, P4 中任意一个进程的需求,所以系统不会出现死锁,处于安全状态。
选项 II:当 Available 为 (0, 6, 2) 时,可以满足进程 P0, P3 的需求;这两个进程结束后释放资源,Available 为 (0, 6, 7),仅可以满足进程 4 的需求;P4 结束并释放后,Available 为 (0, 6, 8),此时不能满足余下任意一个进程的需求,因此当前处在非安全状态。
选项 III:当 Available 为 (1, 1, 1) 时,可以满足进程 P0, P2 的需求;这两个进程结束后释放资源,Available 为 (2, 4, 9),此时不能满足余下任意一个进程的需求,处于非安全状态。
选项 IV:当 Available 为 (0, 4, 7) 时,可以满足 P0 的需求,进程结束后释放资源,Available 为 (0, 4, 10),此时不能满足余下任意一个进程的需求,处于非安全状态。
综上分析:只有选项 I 处于安全状态。27. 死锁定理是用于处理死锁的( )方法。
A. 预防死锁 B. 避免死锁 C. 检测死锁 D. 解除死锁
27. C
死锁定理是用于检测死锁的方法。
28. 某系统有m个同类资源供n个进程共享,若每个进程最多申请k个资源(k≥1),采用银行家算法分配资源,为保证系统不发生死锁,则各进程的最大需求量之和应( )。
A. 等于m B. 等于m + n C. 小于m + n D. 大于m + n
28. C
按照银行家算法,只要保证系统中进程申请的最大资源数小于或等于 m,就一定存在一个安全序列。考虑最极端的情况,假如有 n - 1 个进程都申请了 1 个资源,剩下一个进程申请了 m 个资源,则各进程的最大需求量之和为 m + n - 1,此时能保证一定不会发生死锁。
29.采用银行家算法可以避免死锁的发生,这是因为该算法( )。
A. 可以抢夺已分配的资源
B. 能及时为各进程分配资源
C. 任何时刻都能保证每个进程能得到所需的资源
D. 任何时刻都能保证至少有一个进程可以得到所需的全部资源29. D
任何时刻都能保证至少有一个进程可以得到所需的全部资源,这意味着银行家算法可以保证系统中至少存在一个安全序列,使每个进程都能按该顺序得到所需的全部资源并正常结束,不会出现死锁的情况。这也是银行家算法避免死锁的核心思想。
30.用银行家算法避免死锁时,检测到( )时才分配资源。
A. 进程首次申请资源时对资源的最大需求量超过系统现存的资源量
B. 进程已占有的资源数与本次申请的资源数之和超过对资源的最大需求量
C. 进程已占有的资源数与本次申请的资源数之和不超过对资源的最大需求量,且现存资源量能满足尚需的最大资源量
D. 进程已占有的资源数与本次申请的资源数之和不超过对资源的最大需求量,且现存资源量能满足本次申请量,但不能满足尚需的最大资源量30. C
银行家算法要求,进程运行之前先声明它对各类资源的最大需求量,并保证它在任何时刻对每类资源的请求量不超过它所声明的最大需求量。当进程已占有的资源数与本次申请的资源数之和不超过对资源的最大需求量,且现存资源量能满足尚需的最大资源量时,才分配资源。
31.下列各种方法中,可用于解除已发生死锁的是( )。
A. 撤销部分或全部死锁进程
B. 剥夺部分或全部死锁进程的资源
C. 降低部分或全部死锁进程的优先级
D. A 和 B 都可以31. D
解除死锁的方法有两种:撤销死锁进程和剥夺死锁进程的资源。降低死锁进程的优先级是无效的方法,因为它不能改变死锁进程对资源的需求和占有,也不能打破循环等待条件。
32.假定某计算机系统有R1和R2两类可使用资源(其中R1有两个单位,R2有一个单位),它们被进程P1和P2所共享,且已知两个进程均按下列顺序使用两类资源:申请R1→申请R2→申请R1→释放R1→释放R2→释放R1,则在系统运行过程中,( )。
A. 不可能产生死锁
B. 有可能产生死锁,因为R1资源不足
C. 有可能产生死锁,因为R2资源不足
D. 只有一种进程执行序列可能导致死锁32. B
当两个进程都执行完第一步后,即进程 P1 和进程 P2 都申请到了一个 R1 类资源时,随着两个进程向前推进,无论哪个进程执行完第二步,系统都将进入死锁状态,进入死锁状态的原因是两个进程都需要两个 R1 类资源才能运行,但系统中此时已经没有可供分配的 R1 类资源。假定进程 P1 成功执行了第二步,则死锁发生时资源分配图如下:
进程
已分配资源
申请资源
P1
R1、R2
R1
P2
R1
R1
![]()
33.【2009 统考真题】某计算机系统中有 8 台打印机,由K个进程竞争使用,每个进程最多需要 3 台打印机。该系统可能发生死锁的K的最小值是( )。
A. 2 B. 3 C. 4 D. 533. C
这类题可用到组合数学中鸽巢原理的思想。考虑最极端的情况,因为每个进程最多需要 3 台打印机,若每个进程已经占有了 2 台打印机,则只要还有多的打印机,总能满足一个进程达到 3 台的条件,然后顺利执行,所以将 8 台打印机分给 K 个进程,每个进程有 2 台打印机,这个情况就是极端情况,K 为 4。或者,假设 M 是打印机的数量,K 是进程的数量,R 是每个进程最多需要打印机的数量。根据死锁公式逆推可得,若 M ≤ K (R - 1),则系统可能发生死锁。将本题的数据代入,可得8≤K×(3−1),即K≥4,所以系统可能发生死锁的K的最小值是4。
34.【2011 统考真题】某时刻进程的资源使用情况见下表,此时的安全序列是( )。
A. P1,P2,P3,P4 B. P1,P3,P2,P4
C. P1,P4,P3,P2 D. 不存在
34. D
本题应采用排除法,逐个代入分析。剩余资源分配给P1,待P1执行完后,可用资源数为(2,2,1),此时仅能满足P4的需求,排除选项 A、B;接着分配给P4,待P4执行完后,可用资源数为(2,2,2),此时已无法满足任何进程的需求,排除选项 C。
此外,本题还可以使用银行家算法求解(对选择题来说显得过于复杂)。本题可根据银行家算法的安全性检查来判断是否存在安全序列。
步骤一:计算各进程的尚需资源数
已知各进程的已分配资源和尚需分配资源,根据公式 “尚需资源数 = 最大需求资源数 - 已分配资源数”,结合题目表格信息,可得到各进程的尚需资源数。步骤二:进行安全性检查
从可用资源(0,2,1)开始,逐一检查各进程的尚需资源数是否能被当前可用资源满足。对于P1,尚需(0,0,1),可用资源(0,2,1)可以满足,P1完成后释放资源,此时可用资源变为(2,2,1)。
对于P2,尚需(1,3,2),当前可用资源(2,2,1)不能满足。
对于P3,尚需(2,0,0),当前可用资源(2,2,1)可以满足,P3完成后释放资源,此时可用资源变为(2,3,2)。
对于P4,尚需(2,0,0),当前可用资源(2,3,2)可以满足,P4完成后释放资源,此时可用资源变为(2,3,3)。
此时,仍无法满足P2的需求,所以不存在一个安全序列能让所有进程顺利完成。
综上,答案选 D。
35.【2012 统考真题】假设 5 个进程P0,P1,P2,P3,P4共享三类资源R1,R2,R3,这些资源总数分别为 18, 6, 22。T0时刻的资源分配情况如下表所示,此时存在的一个安全序列是( )。
A. P0,P2,P4,P1,P3
B. P1,P0,P3,P4,P2
C. P2,P1,P0,P3,P4
D. P3,P4,P2,P1,P035. D
首先求得各进程的需求矩阵Need与可利用资源向量Available:
进程名
Need(R1,R2,R3)
P0
2,3,7
P1
1,3,3
P2
0,0,6
P3
2,2,1
P4
1,1,0
资源类型
Available(R1,R2,R3)
2,3,3
比较Need和Available发现,初始时进程P1与P3可满足需求,排除选项 A、C。尝试给P1分配资源时,P1完成后Available将变为(6,3,6),无法满足P0的需求,排除选项 B。尝试给P3分配资源时,P3完成后Available将变为(4,3,7),该向量能满足其他所有进程的需求。因此以P3开头的所有序列都是安全序列。
36.【2013 统考真题】下列关于银行家算法的叙述中,正确的是( )。
A. 银行家算法可以预防死锁
B. 当系统处于安全状态时,系统中一定无死锁进程
C. 当系统处于不安全状态时,系统中一定会出现死锁进程
D. 银行家算法破坏了死锁必要条件中的 “请求和保持” 条件
36. B
银行家算法是用于避免死锁的算法,而不是预防死锁,选项 A 错误。
当系统处于安全状态时,意味着存在一个安全序列,按照这个序列可以为各个进程分配资源,使它们都能顺利完成,所以系统中一定无死锁进程,选项 B 正确。
当系统处于不安全状态时,只是说明可能会进入死锁状态,但不一定会出现死锁进程,选项 C 错误。
银行家算法并没有破坏死锁必要条件中的 “请求和保持” 条件,它是通过在资源分配前进行安全性检查来避免系统进入不安全状态,从而避免死锁,选项 D 错误。37.【2014 统考真题】某系统有n台互斥使用的同类设备,三个并发进程分别需要 3, 4, 5 台设备,可确保系统不发生死锁的设备数n最小为( )。
A. 9 B. 10 C. 11 D. 1237. B
根据死锁公式,当资源数量大于各个进程所需资源数 - 1 的总和时,不发生死锁,三个进程分别需要 3, 4, 5 台设备,即当资源数量大于(3−1)+(4−1)+(5−1)=9时,不发生死锁。而当系统中只有 9 台设备时,第一个进程分配 2 台,第二个进程分配 3 台,第三个进程分配 4 台,这种情况下,三个进程均无法继续执行下去,发生死锁。当系统再增加 1 台设备,最后 1 台设备分配给任意一个进程都可以顺利执行完成,因此保证系统不发生死锁的最小设备数为 10。
38.【2015 统考真题】若系统S1采用死锁避免方法,S2采用死锁检测方法。下列叙述中,正确的是( )。
I. S1会限制用户申请资源的顺序,而S2不会
II. S1需要进程运行所需的资源总量信息,而S2不需要
III. S1不会给可能导致死锁的进程分配资源,而S2会
A. 仅 I、II B. 仅 II、III C. 仅 I、III D. I、II、III38. B
死锁的处理采用三种策略:死锁预防、死锁避免、死锁检测和解除。
死锁预防采用破坏产生死锁的 4 个必要条件中的一个或几个来防止发生死锁。其中之一的 “破坏循环等待条件”,一般采用顺序资源分配法,即限制了用户申请资源的顺序,因此 I 的前半句属于死锁预防的范畴。此外,银行家算法虽然会通过检测是否存在安全序列来判断申请资源的请求是否合法,但安全序列并不是唯一的,也不是固定的,它只是一种可能的分配方案,而不是一种必须遵循的规则,银行家算法更没有给出固定的申请资源的顺序,因此 I 错误。
银行家算法是最著名的死锁避免算法,其中的最大需求矩阵 Max 定义了每个进程对 m 类资源的最大需求量,系统在执行安全性算法中都会检查此次资源试分配后,系统是否处于安全状态,若不安全则将本次的试探分配作废。在死锁的检测和解除中,系统为进程分配资源时不采取任何措施,但提供死锁检测和解除的手段,一旦检测到系统发生死锁,就立即采取相应的措施来解除死锁,因此不用关心进程所需的总资源量。选项 II、III 正确。39.【2016 统考真题】系统中有 3 个不同的临界资源R1、R2和R3,被 4 个进程P1、P2、P3、P4共享。各进程对资源的需求为:P1申请R1和R2,P2申请R2和R3,P3申请R1和R3,P4申请R2。若系统出现死锁,则处于死锁状态的进程数至少是( )。
A. 1 B. 2 C. 3 D. 439. C
对于本题,需先画出如下所示的资源分配图。若系统出现死锁,则必然出现循环等待的情况。
从图中可以看出,若出现循环等待的情况,则至少有P1、P2、P3三个进程在循环等待环中,在该图中不可能出现两个进程发生循环等待的情况。现在考察P1、P2、P3三个进程形成环路的情况,若此时P1、P2、P3三个进程分别拥有R1、R2和R3,则会形成P1等待P2释放R2,P2等待P3释放R3,P3等待P1释放R1的循环等待情况。P1、P2、P3三个进程分别拥有R2、R3和R1的情况的分析类似。以上两种情况都会形成循环等待情况,至少有三个进程陷入死锁状态。若P4事先已获取R2,成功运行,则死锁进程数为 3;若P4尚未获取R2,未运行,则死锁进程数为 4。因此,若系统出现死锁,则处于死锁状态的进程至少是3个。
40.【2018 统考真题】假设系统中有 4 个同类资源,进程P1、P2和P3需要的资源数分别为 4, 3 和 1,P1、P2和P3已申请到的资源数分别为 2, 1 和 0,则执行安全性检测算法的结果是( )。
A. 不存在安全序列,系统处于不安全状态
B. 存在多个安全序列,系统处于安全状态
C. 存在唯一安全序列P3,P1,P2,系统处于安全状态
D. 存在唯一安全序列P3,P2,P1,系统处于安全状态40. A
由题意可知,仅剩最后一个同类资源,若将其分给P1或P2,则均无法正常执行;若分给P3,则P3正常执行完成后,释放的这一个资源仍无法使P1、P2正常执行,因此不存在安全序列。
41.【2019 统考真题】下列关于死锁的叙述中,正确的是( )。
I. 可以通过剥夺进程资源解除死锁
II. 死锁的预防方法能确保系统不发生死锁
III. 银行家算法可以判断系统是否处于死锁状态
IV. 当系统出现死锁时,必然有两个或两个以上的进程处于阻塞态
A. 仅 II、III B. 仅 I、II、IV C. 仅 I、II、III D. 仅 I、III、IV41. B
剥夺进程资源,将其分配给其他死锁进程,可以解除死锁,选项 I 正确。
死锁预防是死锁处理策略(死锁预防、死锁避免、死锁检测)中最为严苛的一种策略,破坏死锁产生的 4 个必要条件之一,可以确保系统不发生死锁,选项 II 正确。
银行家算法是一种死锁避免算法,用于计算动态资源分配的安全性以避免系统进入死锁状态,不能用于判断系统是否处于死锁,选项 III 错误。
通过简化资源分配图可以检测系统是否为死锁状态,当系统出现死锁时,资源分配图不可完全简化,只有两个或两个以上的进程才会出现 “环” 而不能被简化,选项 IV 正确。
42.【2020 统考真题】某系统中有 A、B 两类资源各 6 个,t时刻的资源分配及需求情况如下表所示。
t时刻安全性检测结果是( )。
A. 存在安全序列P1、P2、P3
B. 存在安全序列P2、P1、P3
C. 存在安全序列P2、P3、P1
D. 不存在安全序列42. B
首先求出需求矩阵:
由Allocation得知当前Available为(1,0)。由需求矩阵可知,初始只能满足P2的需求,选项 A 错误。P2释放资源后Available变为(3,1),此时仅能满足P1的需求,选项 C 错误。P1释放资源后Available变为(5,4),可以满足P3的需求,得到的安全序列为P2,P1,P3,B 正确,选项 D 错误。
43.【2021 统考真题】若系统中有n(n≥2)个进程,每个进程均需要使用某类临界资源 2 个,则系统不会发生死锁所需的该类资源总数至少是( )。
A. 2 B. n C. n+1 D. 2n43. C
考虑极端情况,当临界资源数为n时,每个进程都拥有 1 个临界资源并等待另一个资源,会发生死锁。当临界资源数为n+1时,则n个进程中至少有一个进程可以获得 2 个临界资源,顺利运行完后释放自己的临界资源,使得其他进程也能顺利运行,不会产生死锁。或者,根据死锁公式m>n(r−1),其中m是系统中临界资源的总数,n是并发进程的个数,r是每个进程所需临界资源的个数。若这个不等式成立,则系统不发生死锁。将本题的数据代入,得到m>n(2−1),即只要系统中临界资源的总数至少是n+1,就可避免死锁。
44.【2022 统考真题】系统中有三个进程P0、P1、P2及三类资源 A、B、C。若某时刻系统分配资源的情况如下表所示,则此时系统中存在的安全序列的个数为( )。
A. 1 B. 2 C. 3 D. 4
44. B
初始时系统中的可用资源数为<1,3,2>,只能满足P0的需求<0,2,1>,所以安全序列第一个只能是P0,将资源分配给P0后,P0执行完释放所占资源,可用资源数变为<1,3,2>+<2,0,1>=<3,3,3>,此时可用资源数既能满足P1,又能满足P2,可以先分配给P1,P1执行完释放资源再分配给P2;也可以先分配给P2,P2执行完释放资源再分配给P1。所以安全序列可以是①P0、P1、P2或②P0、P2、P1。
二、综合应用题
1.设系统中有下述解决死锁的方法:
1)银行家算法。
2)检测死锁,终止处于死锁状态的进程,释放该进程占有的资源。
3)资源预分配。
简述哪种办法允许最大的并发性,即哪种办法允许更多的进程无等待地向前推进。请按 “并发性” 从大到小对上述三种办法排序。01. 【解答】
死锁在系统中不可能完全消灭,但我们要尽可能地减少死锁的发生。对死锁的处理有 4 种方法:忽略、检测与恢复、避免和预防,每种方法对死锁的处理从宽到严,同时系统并发性由大到小。这里银行家算法属于避免死锁,资源预分配属于预防死锁。
死锁检测方法可以获得最大的并发性。并发性排序:死锁检测方法、银行家算法、资源预分配法。2.某银行计算机系统要实现一个电子转账系统,基本业务流程是:首先对转出方和转入方的账户进行加锁,然后进行转账业务,最后对转出方和转入方的账户进行解锁。若不采取任何措施,系统会不会发生死锁?为什么?请设计一个能够避免死锁的办法。
02. 【解答】
系统会死锁。因为对两个账户进行加锁操作是可以分割进行的,若此时有两个用户同时进行转账,P1先对账户A进行加锁,再申请账户B;P2先对账户B进行加锁,再申请账户A,此时产生死锁。解决的办法是:可以采用资源顺序分配法对A、B账户进行编号,用户转账时只能按照编号由小到大进行加锁;也可采用资源预分配法,要求用户在使用资源前将所有资源一次性申请到。
3.设有进程P1和进程P2并发执行,都需要使用资源R1和R2,使用资源的情况见下表。
试判断是否会发生死锁,并解释和说明产生死锁的原因与必要条件。
03. 【解答】
这段程序在不同的运行推进速度下,可能产生死锁。例如,进程P1先申请资源R1,得到资源R1,然后进程P2申请资源R2,得到资源R2,进程P1又申请资源R2,因资源R2已分配,使得进程P1阻塞。进程P1和进程P2都因申请不到资源而形成死锁。若改变进程的运行顺序,则这两个进程就不会出现死锁现象。
产生死锁的原因可归结为两点:
1)竞争资源。
2)进程推进顺序非法。
产生死锁的必要条件:
1)互斥条件。
2)请求并保持条件。
3)不剥夺条件。
4)环路等待条件。4.系统有同类资源m个,供n个进程共享,若每个进程对资源的最大需求量为k,试问:当m,n,k的值分别为下列情况时(见下表),是否会发生死锁?
04. 【解答】
不发生死锁要求,必须保证至少有一个进程得到所需的全部资源并执行完毕,m≥n(k−1)+1时,一定不会发生死锁。
序号
m
n
k
是否会死锁
说明
1
6
3
3
可能会
6<3(3−1)+1
2
9
3
3
不会
9>3(3−1)+1
3
13
6
3
不会
13=6(3−1)+1
5.有三个进程P1、P2和P3并发工作。进程P1需要资源S3和资源S1;进程P2需要资源S2和资源S1;进程P3需要资源S3和资源S2。问:
1)若对资源分配不加限制,会发生什么情况?为什么?
2)为保证进程正确运行,应采用怎样的分配策略?列出所有可能的方法。05. 【解答】
1)可能发生死锁。满足发生死锁的 4 大条件,例如,P1占有S1申请S3,P2占有S2申请S1,P3占有S3申请S2。
2)可有以下几种答案:
A. 采用静态分配:因为执行前已获得所需的全部资源,所以不会出现占有资源又等待别的资源的现象(或不会出现循环等待资源的现象)。
B. 采用按序分配:不会出现循环等待资源的现象。
C. 采用银行家算法:因为在分配时,保证了系统处于安全状态。6.某系统有R1、R2和R3共三种资源,在T0时刻P1、P2、P3和P4这四个进程对资源的占用和需求情况见下表,此时系统的可用资源向量为 (2, 1, 2)。试问:
1)系统是否处于安全状态?若安全,则请给出一个安全序列。2)若此时进程P1和进程P2均发出资源请求向量 Request (1, 0, 1),为了保证系统的安全性,应如何分配资源给这两个进程?说明所采用策略的原因。
3)若 2)中两个请求立即得到满足后,系统此刻是否处于死锁状态?
进程名
资源情况
最大资源需求量
已分配资源数量
R1
R2
R3
R1
R2
R3
P1
3
2
2
1
0
0
P2
6
1
3
4
1
1
P3
3
1
4
2
1
1
P4
4
2
2
0
0
2
06. 【解答】
1)利用安全性算法对T0时刻的资源分配情况进行分析,可得到如下表所示的安全性检测情况。可以看出,此时存在一个安全序列{P2,P3,P4,P1},所以该系统是安全的。
此处要注意,一般大多数题目中的安全序列并不唯一。
2)若此时P1发出资源请求Request1(1,0,1),则按银行家算法进行检查:
Request1(1,0,1)≤Need1(2,2,2)
Request1(1,0,1)≤Available(2,1,2)
试分配并修改相应数据结构,由此形成的进程P1请求资源后的资源分配情况见下表。
再利用安全性算法检查系统是否安全,可用资源Available(1,1,1)已不能满足任何进程,系统进入不安全状态,此时系统不能将资源分配给进程P1。
若此时进程P2发出资源请求Request2(1,0,1),则按银行家算法进行检查:
Request2(1,0,1)≤Need2(2,0,2)
Request2(1,0,1)≤Available(2,1,2)
试分配并修改相应数据结构,由此形成的进程P2请求资源后的资源分配情况下表:
再利用安全性算法检查系统是否安全,可得到如下表中所示的安全性检测情况。注意表中各个进程对应的 Work + Allocation 向量表示在该进程释放资源之后更新的 Work 向量。
从上表中可以看出,此时存在一个安全序列{P2,P3,P4,P1},因此该状态是安全的,可以立即将进程P2所申请的资源分配给它。
3)若 2)中的两个请求立即得到满足,则此刻系统并未立即进入死锁状态,因为这时所有的进程未提出新的资源申请,全部进程均未因资源请求没有得到满足而进入阻塞态。只有当进程提出资源申请且全部进程都进入阻塞态时,系统才处于死锁状态。
7.考虑某个系统在下表时刻的状态。
进程名
Allocation
Max
Available
A
B
C
D
A
B
C
D
A
B
C
D
P0
0
0
1
2
0
0
1
2
1
5
2
0
P1
1
0
0
0
1
7
5
0
P2
1
3
5
4
2
3
5
6
P3
0
0
1
4
0
6
5
6
使用银行家算法回答下面的问题:
1)Need 矩阵是怎样的?
2)系统是否处于安全状态?如安全,请给出一个安全序列。
3)若从进程P1发来一个请求 (0, 4, 2, 0),这个请求能否立刻被满足?如安全,请给出一个安全序列。07. 【解答】
1)
2)Work向量初始化值 = Available(1,5,2,0)。
系统安全性分析:![]()
因为存在一个安全序列<P0,P2,P1,P3>,所以系统处于安全状态。
3)Request1(0,4,2,0)<Need1(0,7,5,0)
Request1(0,4,2,0)<Available(1,5,2,0)
假设先试着满足进程P1的这个请求,则Available变为(1,1,0,0)。
系统状态变化见下表:
8.假设具有 5 个进程的进程集合P={P0,P1,P2,P3,P4},系统中有三类资源 A, B, C,假设在某时刻有如下状态:
当前系统是否处于安全状态?若系统中的可利用资源 Available 为 (0, 6, 2),系统是否安全?若系统处在安全状态,请给出安全序列;若系统处在非安全状态,简要说明原因。
进程名
Allocation
Max
Available
A
B
C
A
B
C
A
B
C
P0
0
0
3
0
0
4
1
4
0
P1
1
0
0
1
7
5
P2
1
3
5
2
3
5
P3
0
0
2
0
6
4
P4
0
0
1
0
6
5
08. 【解答】
1)根据Need矩阵可知,初始Work等于Available为(1,4,0),可以满足进程P2的需求;进程P2结束后释放资源,Work为(2,7,5),可以满足P0,P1,P3和P4中任意一个进程的需求,所以系统不会出现死锁,当前处于安全状态。
2)若初始Work=Available为(0,6,2),可满足进程P0,P3的需求;这两个进程结束后释放资源,Work为(0,6,7),仅可满足进程P4的需求;P4结束后释放资源,Work为(0,6,8),此时不能满足余下任意一个进程的需求,系统出现死锁,因此当前系统处在非安全状态。
注意:
在银行家算法中,当实际计算分析系统安全状态时,并不需要逐个进程进行。如本题中,在情况 1)下,当计算到进程P2结束并释放资源时,系统当前空闲资源可满足余下任意一个进程的最大需求量,这时已经不需要考虑进程的执行顺序。系统分配任意一个进程所需的最大需求资源,在其执行结束释放资源后,系统当前空闲资源会增加,所以余下的进程仍然可以满足最大需求量。因此,在这里可以直接判断系统处于安全状态。在情况 2)下,系统当前可满足进程P0,P3的需求,所以可以直接让系统推进到P0,P3执行完并释放资源后的情形,这时系统出现死锁;因为此时是系统空闲资源所能达到的最大值,所以按照其他方式推进,系统必然还是出现死锁。因此,在计算过程中,将每步中可满足需求的进程作为一个集合,同时执行并释放资源,可以简化银行家算法的计算。
2.5 本章疑难点
1. 进程与程序的区别与联系
1)进程是程序及其数据在计算机上的一次运行活动,是一个动态的概念。进程的运行实体是程序,离开程序的进程没有存在的意义。从静态角度看,进程是由程序、数据和进程控制块(PCB)三部分组成的。而程序是一组有序的指令集合,是一种静态的概念。
2)进程是程序的一次执行过程,它是动态地创建和消亡的,具有一定的生命周期,是暂时存在的;而程序则是一组代码的集合,是永久存在的,可长期保存。
3)一个进程可以执行一个或几个程序,一个程序也可构成多个进程。进程可创建进程,而程序不可能形成新的程序。
4)进程与程序的组成不同。进程的组成包括程序、数据和 PCB。
2. 银行家算法的工作原理
银行家算法的主要思想是避免系统进入不安全状态。在每次进行资源分配时,它首先检查系统是否有足够的资源满足要求,若有则先进行试分配,并对分配后的新状态进行安全性检查。若新状态安全,则正式分配上述资源,否则拒绝分配上述资源。这样,它保证系统始终处于安全状态,从而避免了死锁现象的发生。
3. 进程同步、互斥的区别和联系
并发进程的执行会产生相互制约的关系:一种是进程之间竞争使用临界资源,只能让它们逐个使用,这种现象称为互斥,是一种竞争关系;另一种是进程之间协同完成任务,在关键点上等待另一个进程发来的消息,以便协同一致,是一种协作关系。
相关文章:
操作系统学习笔记
2.4 死锁 在学习本节时,请读者思考以下问题: 1)为什么会产生死锁?产生死锁有什么条件? 2)有什么办法可以解决死锁问题? 学完本节,读者应了解死锁的由来、产…...
5.4.云原生与服务网格
目录 1. Kubernetes与微服务集成 1.1 容器化部署规范 • 多环境配置管理(ConfigMap与Nacos联动) • 健康检查探针配置(Liveness/Readiness定制策略) 1.2 弹性服务治理 • HPA自动扩缩容规则设计 • Sentinel指标驱动弹性伸缩 2…...
[特殊字符][特殊字符]Linux驱动开发入门 | 并发与互斥机制详解
文章目录 👨💻Linux驱动开发入门 | 并发与互斥机制详解📌为什么驱动中需要并发和互斥控制?💡常见的并发控制机制🔐自旋锁和信号量通俗理解🌀自旋锁(Spinlock)——“厕所…...
时序数据库IoTDB自研的Timer模型介绍
一、引言 时序数据库在支持时序特性写入、存储、查询等功能的基础上,正逐步向深度分析领域迈进。自动化异常监测与智能化趋势预测已成为时序数据管理的核心需求。为了满足这些需求,时序数据库IoTDB团队积极探索,成功自研推出了面向时间序列的…...
RabbitMQ 详解(核心概念)
本文是博主在梳理 RabbitMQ 知识的过程中,将所遇到和可能会遇到的基础知识记录下来,用作梳理 RabbitMQ 的整体架构和功能的线索文章,通过查找对应的知识能够快速的了解对应的知识而解决相应的问题。 文章目录 一、RabbitMQ 是什么?…...
【数据结构和算法】6. 哈希表
本文根据 数据结构和算法入门 视频记录 文章目录 1. 哈希表的概念1.1 哈希表的实现方式1.2 哈希函数(Hash Function)1.3 哈希表支持的操作 2. Java实现 在前几章的学习中,我们已经了解了数组和链表的基本特性,不管是数组还是链表…...
RHCE第三次作业 搭建dns的正向解析服务器
server为服务器 client为客户端 设置主配置文件 在server下: [rootServer ~]#vim /etc/named.conf #进入到配置页面,并修改 设置区域文件 [rootServer ~]# vim /etc/named.rfc1912.zones 设置域名解析文件 [rootServer named]# cd /var/named…...
【每天一个知识点】如何解决大模型幻觉(hallucination)问题?
解决大模型幻觉(hallucination)问题,需要从模型架构、训练方式、推理机制和后处理策略多方面协同优化。 🧠 1. 引入 RAG 框架(Retrieval-Augmented Generation) 思路: 模型生成前先检索知识库中…...
Python深拷贝与浅拷贝:避开对象复制的陷阱
目录 一、为什么需要区分深浅拷贝? 二、内存中的对象真相 三、浅拷贝的真相 四、深拷贝的奥秘 五、自定义对象的拷贝 六、性能对比实验 七、常见陷阱与解决方案 八、最佳实践指南 九、现代Python的拷贝优化 结语 一、为什么需要区分深浅拷贝? …...
批量处理多个 Word 文档:插入和修改页眉页脚,添加页码的方法
Word 页眉页脚的设置在日常工作中非常常见,尤其是需要统一格式的文档,如毕业论文、公司内部资料等。在这些文档中,页眉页脚通常包含时间、公司标志、文档标题、文件名或作者姓名等信息。有时,我们不仅需要简单的文字页眉页脚&…...
大语言模型(LLM)的Prompt Engineering:从入门到精通
大语言模型(LLM)的Prompt Engineering:从入门到精通 系统化学习人工智能网站(收藏):https://www.captainbed.cn/flu 引言:Prompt Engineering——解锁AI生产力的金钥匙 当ChatGPT在2023年引爆…...
poi生成横向文档以及复杂表头
代码: //创建页面并且创建横向A4XWPFDocument doc new XWPFDocument();CTDocument1 document doc.getDocument();CTBody body document.getBody();if (!body.isSetSectPr()) {body.addNewSectPr();}CTSectPr section body.getSectPr();if (!section.isSetPgSz()) {section.…...
深入剖析TCP协议(内容二):从OSI与TCP/IP网络模型到三次握手、四次挥手、状态管理、性能优化及Linux内核源码实现的全面技术指南
文章目录 常见问题TCP和UDPISNUDPTCP数据可靠性TCP协议如何提高传输效率TCP如何处理拥塞 SocketTCP源码tcp_v4_connect()sys_accept()tcp_accept()三次握手客户端发送SYN段服务端发送SYN和ACK处理客户端回复确认ACK段服务端收到ACK段 常见问题 TCP和UDP TCP和UDP的区别&#…...
流程架构是什么?为什么要构建流程架构,以及如何构建流程结构?
本文从:流程架构是什么?为什么要构建流程架构?如何构建流程结构三个方面来介绍。 一、首先,我们来了解流程架构是什么? 流程架构是人体的骨架,是大楼的砌筑,是课本的目录,是流程管理…...
Visium HD多样本拼片拆分
Visium HD实验的时候一个捕获区域内可以包含多个样本拼片(例如多个组织切片或不同样本的排列)是常见的实验设计,多样本拼片能够提升实验效率,单张玻片处理多个样本,降低试剂和测序成本,后续分析的时候只需要…...
3DMAX零售商店生成插件RetailStore自定义贴图库方法详解
3DMAX零售商店生成插件——RetailStore,是一款兼具简洁性与复杂性的工具,专为通过样条线快速创建零售商店而设计。用户只需绘制一条街道廓线,轻点鼠标,即可生成一排随机的零售商店。该插件会在每个样条线段上自动生成一个店铺&…...
从性能到安全:大型网站系统架构演化的 13 个核心维度
大型网站系统架构的演化是一个复杂的过程,涉及到多个维度的技术内容,从关键维度进行详细分析: 1.性能维度 缓存技术:包括浏览器缓存、CDN(内容分发网络)缓存、服务器端缓存(如 Memcached、Red…...
昆仑万维开源SkyReels-V2,近屿智能紧跟AI技术趋势
昆仑万维 SkyReels 团队正式发布并开源全球首个采用扩散强迫框架的无限时长电影生成模型 SkyReels-V2,其通过融合多模态大语言模型、多阶段预训练、强化学习与扩散强迫框架实现协同优化,推动视频生成技术进入新阶段。该模型聚焦解决现有技术在提示词遵循…...
Milvus(4):创建 Collections
1 创建 Collections 可以通过定义 Schema、索引参数、度量类型以及创建时是否加载来创建一个 Collection。 1.1 集合概述 Collection 是一个二维表,具有固定的列和变化的行。每列代表一个字段,每行代表一个实体。要实现这样的结构化数据管理,…...
数据预处理:前缀和算法详解
数据预处理:前缀和算法详解 文章目录 数据预处理:前缀和算法详解1.算法原理2.算法作用3.C代码实现4.实战题目 1.算法原理 基本概念 前缀和(Prefix Sum)是一种常用的数据预处理技术,它可以快速求解区间和问题…...
盈达科技:登顶GEO优化全球制高点,以AICC定义AI时代内容智能优化新标杆
一、技术制高点——全球独创AICC系统架构,构建AI内容优化新范式 作为全球首个实现AI内容全链路优化的技术供应商,盈达科技凭借AICC智能协同中心(自适应内容改造、智能数据投喂、认知权重博弈、风险动态响应四大引擎)&#…...
【Linux】详细介绍进程的概念
目录 一、初识进程概念 真正的进程概念如下: 二、Linux中PCB的操作系统学科叫法:task_struct 1、简单认识task_ struct内容分类 2、问题:操作系统怎么知道当前程序执行到哪一行代码了? 三、linux关于进程的常用指令ÿ…...
mybatis框架补充
一,#{} 和${}区别 1.传数值 #{} 占位符,是经过预编译的,编译好SQL语句再取值,#方式能够防止sql注入 eg:#{}:delete from admin where id #{id} 结果: dalete from admin where id &#x…...
Alertmanager的安装和详细使用步骤总结
一、安装步骤 1. 二进制安装 下载与解压 从GitHub下载最新版本(如v0.23.0):wget https://github.com/prometheus/alertmanager/releases/download/v0.23.0/alertmanager-0.23.0.linux-amd64.tar.gz tar -xzf alertmanager-0.23.0.linux-amd6…...
C++学习:六个月从基础到就业——C++学习之旅:STL迭代器系统
C学习:六个月从基础到就业——C学习之旅:STL迭代器系统 本文是我C学习之旅系列的第二十四篇技术文章,也是第二阶段"C进阶特性"的第二篇,主要介绍C STL迭代器系统。查看完整系列目录了解更多内容。 引言 在上一篇文章中…...
缓存与数据库一致性方案
一、缓存更新策略概述 在现代分布式系统中,缓存作为数据库的前置层,能显著提升系统性能。然而,缓存与数据库之间的数据一致性是一个经典难题。以下是三种常见的缓存更新策略及其优缺点分析。 二、方案对比分析 方案一:直接更新…...
国内ip地址怎么改?详细教程
在中国,更改IP地址需要遵守规则,并确保所有操作合规。在特定情况下,可能需要修改IP地址以满足不同需求或解决特定问题。以下是一些常见且合法的IP地址变更方法及注意事项: 一、理解IP地址 IP地址是设备在网络中的唯一标识&#x…...
通过Quartus II实现Nios II编程
目录 一、认识Nios II二、使用Quartus II 18.0Lite搭建Nios II硬件部分三、软件部分四、运行项目 一、认识Nios II Nios II软核处理器简介 Nios II是Altera公司推出的一款32位RISC嵌入式处理器,专门设计用于在FPGA上运行。作为软核处理器,Nios II可以通…...
拥抱基因体检,迎接精准健康管理新时代
2025年4月20日,由早筛网、细胞科技网联合中国食品药品企业质量安全促进会细胞医药分会、中国抗衰老促进会健康管理工作委员会、中国抗癌协会肿瘤分子医学专业委员会、广东省保健协会,伯温生物冠名支持的《基因体检赋能精准健康管理新时代》圆满召开。 伯…...
QT容器类控件及其属性
Group Box 使用QGroupBox实现一个带有标题的分组框,可以把其它的控件放到里面作为一组 例: 核心属性 属性 说明 title 分组框的标题 alignment 分组框内部内容的对齐方式 flat 是否”扁平模式” checkable 是否可选中 设为true,则…...
云原生--CNCF-3-核心工具介绍(容器和编排、服务网格和通信、监控和日志、运行时和资源管理,安全和存储、CI/CD等)
1、核心工具分类介绍 (1)、容器编排与管理 1、Docker 它是一款轻量级的容器化技术,可把应用及其依赖打包成独立的容器。借助Docker,开发者能够确保应用在不同环境中保持一致的运行状态。比如在开发环境中创建的容器,…...
网络基础知识
文章目录 一、网络架构1. 网络架构图2. 各层级功能3. 机房网络常见问题及解决方案 二、交换技术1. 交换技术基础2. 交换技术分类3. 广播域相关概念4. ARP 协议5. 三层交换机6. VLAN(虚拟局域网) 三、路由技术1. 路由器端口类型及功能2. 路由器功能3. 路由…...
第3课:运算符与流程控制——JS的“决策者”
一切美好都值得你全力以赴。即使过程艰难,但只要坚持,必有回响。加油! 欢迎来到「JavaScript 魔法学院」第 3 课!今天我们将化身代码世界的“指挥官”,用运算符计算数据,用流程控制做出决策!文…...
VUE3中使用echarts,配置都正确,不出现tooltip
在vue3中使用echarts,出现个别问题,需要注意echars对象的定义,不能使用reactive或者ref定义响应式变量,要使用shallowRef ; shallowRef 是 Vue 3 提供的一个 API,它创建一个响应式引用(ref),但…...
Python实现邮件发送
一、创造灵感 这几天在指导学生做毕业设计,学生做的是跌倒检测。然后我突然想到,如果这个系统只是单纯地从视频流中检测到人的跌倒动作,其实并没有任何的用途和意义。于是,我又想到,如果跌倒的检测结果,能…...
OSPF的优化
OSPF的优化 1、汇总 --- 减少骨干区域LSA的更新量 汇总 --- 区域汇总 域间路由汇总 --- 在ABR设备上,针对3类LSA进行汇总 [r1-ospf-1-area-0.0.0.2]abr-summary 192.168.0.0 255.255.252.0 注:在进行域间路由汇总时,必须是ABR设备自己通过拓…...
IP-guard离线卸载客户端及清除策略说明
1、控制台生成客户端工具 控制台选择“工具-客户端工具-客户端离线辅助工具”,可生成客户端离线卸载工具及 离线策略清除工具,打包生成exe后,可在离线的客户端上运行,实现离线情况下对客户端 进行卸载或者清除策略。 在控制台上“…...
腾讯秋招面试题:bug生命周期中有哪些状态?
在软件测试中,Bug生命周期是质量管控的核心脉络。不同企业的流程或有差异,但核心状态遵循行业通用规范。以下以腾讯TAPD缺陷管理模型为基础,结合互联网大厂主流实践,详解Bug生命周期的关键状态及流转逻辑。 一、基础状态图谱 图表 代码 下载 确认有效 非缺陷/需求不符…...
PyCharm 链接 Podman Desktop 的 podman-machine-default Linux 虚拟环境
#工作记录 PyCharm Community 连接到Podman Desktop 的 podman-machine-default Linux 虚拟环境详细步骤 1. 准备工作 确保我们已在 Windows 系统中正确安装并启动了 Podman Desktop。 我们将通过 Podman Desktop 提供的名为 podman-machine-default 的 Fedora Linux 41 WSL…...
学习海康VisionMaster之卡尺工具
一:进一步学习了 今天学习下VisionMaster中的卡尺工具:主要用于测量物体的宽度、边缘的特征的位置以及图像中边缘对的位置和间距 二:开始学习 1:什么是卡尺工具? 如果我需要检测芯片的每一个PIN的宽度和坐标ÿ…...
私有知识库 Coco AI 实战(二):摄入 MongoDB 数据
在之前的文章中,我们介绍过如何使用《 Logstash 迁移 MongoDB 数据到 Easyseach》,既然 Coco AI 后台数据存储也使用 Easysearch,我们能否直接把 MongoDB 的数据迁移到 Coco AI 的 Easysearch,使用 Coco AI 对数据进行检索呢&…...
【C/C++】插件机制:基于工厂函数的动态插件加载
本文介绍了如何通过 C 的 工厂函数、动态库(.so 文件)和 dlopen / dlsym 实现插件机制。这个机制允许程序在运行时动态加载和调用插件,而无需在编译时知道插件的具体类型。 一、 动态插件机制 在现代 C 中,插件机制广泛应用于需要…...
硬核科普丨2025年安全、高效网络准入控制系统深度解析
阳途网络准入控制系统(Network Access Control,简称NAC)是当代网络安全领域的重要工具,有效防止未经授权的访问和数据泄露,保障网络资源的安全性和完整性。本文将深入探讨阳途网络准入控制系统的的重要性和作用。 一、…...
2025知识管理趋势解析:AI、协作与用户体验引领变革
知识管理软件是多元化的商业工具,包括知识库系统、wiki、协作平台、文档管理工具、聊天机器人和帮助系统,针对企业信息爆炸式增长的趋势,这些工具正逐步成为提升知识工作者效率和客户服务水平的关键支撑。 知识成为新资产:知识工…...
杂谈-有感而发
今天又拜读了线性代数的几何意义这本书,感觉确实是很不错的,从几何角度讲解线性代数,而且将线性代数、几何、数学、物理有机结合起来了,不仅仅是可视化,重要的是能便于自己独立思考下去。 从大一开始,就…...
使用nodeJs的express+axios+cors做代理
使用nodeJs的expressaxioscors做代理 前端在请求后端时通常会遇到跨域cors问题,如果只在本地开发可以通过webpack或vite的proxy设置。但如果需要在线上或者其他地方绕过跨域,可以使用代理的方法。 1. 创建文件夹 并创建以下文件 package.json {"…...
SQL进阶知识:四、索引优化
今天介绍下关于索引优化的详细介绍,并结合MySQL数据库提供实际例子。 索引优化是数据库性能优化的关键环节之一,尤其是在处理大量数据时。索引可以加快查询速度,减少数据扫描范围,但不当的索引设计也可能导致性能问题。以下是关于…...
C++初阶-类和对象(下)
目录 1.再探构造函数 2.类型转换 3.友元 4.static成员 5.内部类 6.匿名对象 *7.对象拷贝时的编译器优化(非必学) 8.总结 1.再探构造函数 (1)之前我们实现构造函数时,初始化成员变量主要使用函数体内赋值&#…...
RPC通信原理实战
RPC概念及RPC请求响应流程 RPC概念引入 假设有两个模块,用户和订单 在单体项目中,两个模块被打包到一个包,都处在一个tomcat进程中,用户模块调用订单模块属于同一进程内的本地调用 在微服务项目中,用户模块和订单模…...
自动创建 中国古代故事人物一致性图画,看看扣子的空间是否能达到你的满意,自媒体的福音?
欢迎来到涛涛聊AI 看效果: AI绘画最难的人物一致性问题,每次得到的结果都不一致。 官方介绍: 扣子空间是你和 AI Agent 协同办公的最佳场所。 在扣子空间里,精通各项技能的「通用实习生」,各行各业的「领域专家」&…...