你知道什么是死锁吗?
多个进程可以竞争有限数量的资源。当一个进程申请资源时,如果这时没有可用资源,那么这个进程进入等待状态。有时,如果所申请的资源被其他等待进程占有,那么该等待进程有可能再也无法改变状态。这种情况成为死锁。
就好比线程1占有线程A需要获取到资源B才能释放资源A的锁,而同时,线程2占有资源B需要在获取资源A才能释放资源B的锁,两个线程就会在一直等待。
死锁的四个条件
如果系统中以下四个条件同时成立,那么就能引起死锁:
互斥
:资源必须处于非共享模式,即一次只有一个进程可以使用。如果另一进程申请该资源,那么必须等待直到该资源被释放为止。占有并等待
:一个进程至少应该占有一个资源,并等待另一资源,而该资源被其他进程所占有。非抢占
:资源不能被抢占。只能在持有资源的进程完成任务后,该资源才会被释放。循环等待
:有一组等待进程 {P0, P1,…, Pn}, P0 等待的资源被 P1 占有,P1 等待的资源被 P2 占有,…,Pn-1 等待的资源被 Pn 占有,Pn 等待的资源被 P0 占有。
如何防止死锁
如何防止死锁?(重点)
1.减少同步代码块嵌套操作
2.降低锁的使用粒度,不要几个功能共用一把锁
3.尽量采用tryLock(timeout)的方法,可以设置超时时间,这样超时之后,就可以主动退出,防止死锁(关键)
标签:占有,避免,面试,死锁,线程,进程,等待,资源 来源: https://blog.csdn.net/weixin_43961117/article/details/121225167
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。