手画图解,关于死锁,面试的一切都在这里了

内容简介:

什么是死锁(Deadlock)
死锁是指两个或两个以上的线程在执行过程中,因争夺资源而造成的一种互相等待的现象。若无外力作用,它们都将无法推进下去。

产生死锁的四个必要条件得烂熟于心:

互斥条件:进程要求对所分配的资源进行排他性控制,即在一段时间内某资源仅为一个进程所占用。此时若有其他进程请求该资源,则请求进程只能等待。

不剥夺条件:进程所获得的资源在未使用完毕之前,不能被其他进程强行夺走,即只能由获得该资源的进程自己来释放。

请求和保持条件:进程已经保持了至少一个资源,但又提出了新的资源请求,而该资源已被其他进程占有,此时请求进程被阻塞,但对自己已获得的资源保持不放。

循环等待条件:存在一种进程资源的循环等待链,连中每一个进程已获得的资源同时被链中下一个进程所请求。

相应的,...

查看原文

? 手画图解,关于死锁,面试的一切都在这里了

版权声明:cnblogshot 发表于 2022-12-16 8:57:20。
转载请注明:手画图解,关于死锁,面试的一切都在这里了 | 程序员导航网

暂无评论

您必须登录才能参与评论!
立即登录
暂无评论...