• 什么是线程死锁?死锁如何产生?如何避免线程死锁?


    例如,假设线程 A 持有资源 X ,并等待资源 Y ,而线程 B 持有资源 Y ,并等待资源 X ,这时候就会出现死锁。

    一、死锁

    死锁 线程死锁是指由于两个或者多个线程互相持有对方所需要 的资源,导致这些线程处于等待状态,无法前往执行.当线程进入对象的synchronized 代码块时,便占有了资源,直到它退出该代码块或者调用wait 方法,才释放资源,在此期间,其他线程将不能进入该代码块。当线程互相持有对方所需要的资源时,会互相等待对方释放资源,如果线程都不主动释放所占有的资源,将产生死 锁。

    二、死锁的产生的一些特定条件:

    Java 中,死锁产生的一些特定条件通常包括以下四个方 面:
    1. 互斥条件 :一个资源一次只能被一个线程持有, 如果其他线程想要获取该资源,就必须等待该线程释放该资源。
    2. 保持 条件:一个线程请求资源时,如果已经持有了其他资源,就可以保持对这些资源的控制,直到满足所有资源的要求才释放。
    3. 不剥夺条件 :已经分配的资源不能被其他线程剥夺,只能由持有资源的线程释放。
    4. 环路 等待条件:多个线程形成一种循环等待的关系,每个线程都在等待其他线程所持有的资源,从而导致死锁的产生。当以上条件同时满足时,就可能会出现死锁的情况。为了避免死锁,需要在设计时遵循一定的规范和原则,例如尽量避免嵌套锁,确保同步代码块执行时间尽可能短等,同时也可以使用专门的工具进行死锁检测和分析,帮助我们找到死锁的根本原因并进行相应的优化和调整。

    三、如何避免

    要避免线程死锁,可以采取以下几种方法:
    1. 尽量避免使用多个锁 ,尽量使用一个锁或者使用更加高级的锁,例如读写锁或ReentrantLock
    2. 确保同步代码块的执行时间尽可能短,这样可以减少线程等待时间,从而避免死锁的产生。
    3. 使用 尝试锁 ,通过 ReentrantLock.tryLock() 方法可以尝试获取锁,如果在规定时间内获取不到锁,则放弃锁。
    4. 避免 嵌套锁 ,如果需要使用多个锁,请确保它们的获取顺序是一致的,这样可以避免死锁
  • 相关阅读:
    安装Linux虚拟机并在Llinux中安装Redis、MySQL
    SNMP放大攻击
    数据结构基础学习
    flink学习之state
    [附源码]计算机毕业设计springboot游戏商城平台论文
    搭建Redis主从复制、哨兵模式
    PS软件 点击 “另存为 Web 所用格式” ,提示错误 无法完成操作 系统找不到指定路径
    高德地图API-通过经纬度获取当前位置附近的建筑
    微信公众号迁移步骤
    基础算法练习200题11、鸡兔同笼
  • 原文地址:https://blog.csdn.net/qq_62975017/article/details/132889789