线程死锁,死锁条件,如何避免死锁

死锁:有两个或两个以上线程相互持有对方所需要的资源,而使得这些线程无法往下执行下去。在Java中程序执行进入对象的synchronized代码块中,执行的线程是独占该资源的。在执行完成前的这段时间里,其他线程都不能进入该代码块中执行,直到占有线程退出syncronized代码块,其他线程才能进入该syncronized代码块。当线程相互持有对方线程所需要的系统资源时,或相互等待对方释放系统资源,当相互都不释放所占有的资源时,死锁也就由此产生。


死锁条件:1.互斥条件----进程对所分配到的资源具有排他性,即一个资源只能被一个进程锁拥有,直到进程释放资                                                源。

                    2.请求和保持条件----一个进程因请求被占用的资源而发生阻塞时,对自己已获得的资源保持持有不释放

                    3.不剥夺条件----任何一个资源在没有被进程释放前,其他进程都无法对其剥夺占有。

                    4.循环等待条件----当发生死锁时,所等待的进程必定会形成一个环路,造成永久堵塞。



避免死锁:1.加锁顺序-----当多个线程要相同的一些锁,但是按照不同的顺序加锁,死锁的情况发生率较高,如果,程序运行能确保所有线程都是按照相同的顺序去获得锁,那么死锁就不会发生。

                    2.加锁时限-----加一个超时时间,若一个线程没有在给定的时间内成功获取所需的锁,则进行回退操作,并释放自己本身所持有的锁,一段随机时间之后,重新去获取锁。

                      3.死锁检测-----死锁检测,每当线程去获取锁的时候,会在线程和锁相关的数据结构中将其记下,除此之外,每当线程请求锁,都需要记录在数据结构中。死锁检测是一个死锁避免机制。他主要针对的时那些不可能实现按序加锁并且锁超时也不可行的应用场景。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1、竞态条件: 定义:竞态条件指的是一种特殊的情况,在这种情况下各个执行单元以一种没有逻辑的顺序执行动作,从而导致...
    Hughman阅读 1,427评论 0 7
  • 在开发Java多线程应用程序中,各个线程之间由于要共享资源,必须用到锁机制。Java提供了多种多线程锁机制的实现方...
    千淘萬漉阅读 7,101评论 1 33
  • 即使已经知道会发生什么,在整个大楼发生爆炸前的那一刻路小花还是义无反顾的冲了进去 随后的爆炸声惊动了整个城市 俄罗...
    墨小花阅读 345评论 0 1
  • . A life full of good habits will be a life conforming wi...
    小绿植物阅读 249评论 0 0
  • 2018-4-30 6:30-22:30 虽说51放假只有简短的两日,一周上班都是过着三点一线的生活,对于...
    周游远行阅读 460评论 0 1

友情链接更多精彩内容