news 2026/4/16 16:58:09

高频面试题:Java死锁问题如何解决?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
高频面试题:Java死锁问题如何解决?

大家好,我是锋哥。今天分享关于【高频面试题:Java死锁问题如何解决?】面试题。希望对大家有帮助;

高频面试题:Java死锁问题如何解决?

死锁产生的四个必要条件(缺一不可)

  1. 互斥(Mutual Exclusion)—— 锁只能被一个线程持有
  2. 持有并等待(Hold and Wait)—— 持有至少一个锁,同时等待另一个锁
  3. 不可抢占(No Preemption)—— 锁只能由持有者主动释放
  4. 循环等待(Circular Wait)—— 线程之间形成环形等待链

解决死锁的核心思想:破坏上面任意一个条件(最常用的是破坏第4个,其次是第2个)。

实际开发中最有效的解决 & 预防手段(按推荐优先级排序)

优先级方法核心思想适用场景缺点/代价代码示例关键点
★★★★★固定锁获取顺序(Lock Ordering)破坏循环等待绝大多数业务场景需要提前规划锁的全局顺序所有线程都按相同顺序获取锁(如按id排序)
★★★★☆使用带超时的锁(tryLock)破坏不可抢占 + 持有并等待锁竞争激烈、容易死锁的场景业务需处理获取失败的情况ReentrantLock.tryLock(时间, 时间单位)
★★★★☆减小锁粒度 + 缩短锁持有时间减少持有并等待时间窗口锁保护范围过大的代码代码改动较大只在真正需要线程安全的地方加锁
★★★☆☆避免嵌套锁 / 锁的交叉使用避免持有并等待老代码重构、复杂业务逻辑有时难以完全消除尽量把获取第二个锁的代码移出第一个锁范围
★★★☆☆一次性申请所有资源破坏持有并等待资源有限且数量可知的场景实现复杂,容易浪费资源类似银行家算法或先尝试获取所有锁
★★☆☆☆使用更高级的并发工具从根本上减少显式加锁可以用新结构替换旧代码的地方学习成本、改造成本较高ConcurrentHashMap、CopyOnWrite、StampedLock、CompletableFuture 等
★★☆☆☆死锁检测 + 自动恢复事后补救(非首选)极难避免死锁的遗留系统业务可能受损,复杂ThreadMXBean.findDeadlockedThreads()

最常用、最推荐的代码实践写法对比

容易死锁的写法(经典转账示例)

public void transfer(Account from, Account to, int amount) { synchronized (from) { synchronized (to) { // 嵌套锁 + 顺序不一致 → 极易死锁 // 转账逻辑 } } }

推荐写法1:固定锁顺序(最常用、最安全)

public void transfer(Account from, Account to, int amount) { // 按账户ID的自然顺序加锁(破坏循环等待) Account first = from.getId() < to.getId() ? from : to; Account second = first == from ? to : from; synchronized (first) { synchronized (second) { // 转账逻辑 } } }

推荐写法2:使用带超时的 ReentrantLock(更灵活)

private final ReentrantLock lock1 = new ReentrantLock(); private final ReentrantLock lock2 = new ReentrantLock(); public boolean transferWithTimeout() { try { if (!lock1.tryLock(5, TimeUnit.SECONDS)) { return false; // 或抛出自定义异常 } try { if (!lock2.tryLock(5, TimeUnit.SECONDS)) { return false; } try { // 转账逻辑 return true; } finally { lock2.unlock(); } } finally { lock1.unlock(); } } catch (InterruptedException e) { Thread.currentThread().interrupt(); return false; } }

快速记忆口诀(生产环境最常说的一句话)

“要么锁的顺序全局统一,要么加锁带超时,其他都是辅助手段。”

最后几条生产环境铁律

  1. 尽量避免在 synchronized 块里调用外部方法(尤其是可能阻塞、IO、网络、加锁的方法)
  2. 锁保护的范围越小越好,能用局部变量锁就别用对象锁
  3. 能用java.util.concurrent包下的工具就尽量别手写 synchronized + wait/notify
  4. 定期做代码审查,特别关注多个锁同时出现的业务逻辑
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 21:59:33

基于A2A协议的Golang多智能体协同系统实战

引言 随着人工智能技术的迅猛发展,单一智能体系统已难以应对日益复杂的现实世界任务。多智能体系统(Multi-Agent System, MAS)通过分布式智能体之间的协同与合作,展现出强大的问题解决能力,在自动驾驶、智能制造、智慧城市等领域得到广泛应用。 在多智能体系统中,智能体…

作者头像 李华
网站建设 2026/4/16 7:20:59

开源二手交易小程序源码系统,打造个性化商城,功能一应俱全

温馨提示&#xff1a;文末有资源获取方式 今天&#xff0c;我要向大家推荐一款全面的二手交易小程序源码系统&#xff0c;它基于先进的技术栈开发&#xff0c;源码完全开源&#xff0c;支持二次开发&#xff0c;让您轻松搭建属于自己的二手交易商城。源码获取方式在源码闪购网。…

作者头像 李华
网站建设 2026/4/16 7:23:43

好写作AI:从数据到观点——AI在实证研究中的逻辑链条构建

当数据沉默时&#xff0c;谁能为它发声&#xff1f;面对满屏的实验数据、调查统计和案例分析&#xff0c;许多学生陷入相似的困境&#xff1a;“我的数据说明了什么&#xff1f;”“如何让这些数字形成有说服力的论证&#xff1f;”实证研究的核心挑战&#xff0c;往往不在于数…

作者头像 李华
网站建设 2026/4/16 9:02:05

书匠策AI:教育论文数据分析的“时空折叠器”,让你的研究穿越未来

在教育研究的宇宙中&#xff0c;数据是星辰&#xff0c;分析是望远镜&#xff0c;而结论则是我们试图捕捉的遥远星系。但传统数据分析工具像一台老式天文台——操作复杂、视野有限&#xff0c;研究者常被困在“清洗数据”“调试代码”“选择图表”的琐碎中&#xff0c;真正的研…

作者头像 李华
网站建设 2026/4/15 23:47:17

书匠策AI:教育论文的“数据炼金术士”,让数字开口说故事的秘密武器——官网:http://www.shujiangce.com | 微信公众号搜一搜“书匠策AI”

在学术写作的江湖里&#xff0c;数据是“武林秘籍”&#xff0c;而数据分析则是“绝世武功”。但面对SPSS的报错、Python的代码、R语言的版本兼容问题&#xff0c;许多教育研究者常陷入“数据焦虑”&#xff1a;明明有满脑子的理论&#xff0c;却被技术门槛卡在论文的“最后一公…

作者头像 李华
网站建设 2026/4/16 7:56:45

Linux 命令:uniq

概述 uniq 命令是对连续重复行去重/统计的工具&#xff0c;常与 sort 配合使用&#xff08;先排序让重复行连续&#xff0c;再去重&#xff09;&#xff0c;核心用于文本去重、统计重复行出现次数&#xff0c;是处理日志、数据清单的高频组合工具&#xff0c;注意&#xff1a;直…

作者头像 李华