当前位置: 首页 > news >正文

Java是怎么处理死锁的

文章目录

  • 避免死锁
    • 避免嵌套锁
    • 资源进行排序
    • 超时锁
  • 检测死锁
    • 通过Java提供的API检查死锁情况
    • jStack监控工具

Java 本身没有内置的机制自动处理死锁问题,但可以采取一些策略和技术来检测和避免死锁。

避免死锁

避免嵌套锁

尽可能减少嵌套锁操作,避免在一个锁定资源时去锁定另一个资源。

资源进行排序

通过事先定义资源获取的顺序,确保所有线程按照相同的顺序获取资源,这样可以避免循环等待。

synchronized (resource1) {synchronized (resource2) {// code}
}

超时锁

使用 tryLock 方法来尝试获取锁,并设置获取锁的超时时间。如果在超时时间内未能获取锁,则执行相应的超时处理,这样可以避免永久等待锁的情况。

tryLock使用CAS操作尝试获取锁,如果获取锁失败,则返回false,并不会阻塞线程。

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
import java.util.concurrent.TimeUnit;Lock lock1 = new ReentrantLock();
Lock lock2 = new ReentrantLock();if (lock1.tryLock(1000, TimeUnit.MILLISECONDS)) {if (lock2.tryLock(1000, TimeUnit.MILLISECONDS)) {try {// critical section} finally {lock2.unlock();lock1.unlock();}} else {lock1.unlock();// handle timeout}
} else {// handle timeout
}

检测死锁

通过Java提供的API检查死锁情况

Java 提供了 ThreadMXBean 来检测死锁。可以通过调用 findDeadlockedThreads 方法来获取涉及死锁的线程。

import java.lang.management.ManagementFactory;
import java.lang.management.ThreadInfo;
import java.lang.management.ThreadMXBean;public class DeadlockDetector {private final ThreadMXBean threadMXBean;public DeadlockDetector() {this.threadMXBean = ManagementFactory.getThreadMXBean();}public void detectDeadlock() {long[] deadlockedThreadIds = threadMXBean.findDeadlockedThreads();if (deadlockedThreadIds != null && deadlockedThreadIds.length > 0) {ThreadInfo[] threadInfos = threadMXBean.getThreadInfo(deadlockedThreadIds);System.out.println("死锁检测到以下线程:");for (ThreadInfo threadInfo : threadInfos) {System.out.println(threadInfo.getThreadName() + " 处于死锁状态");}} else {System.out.println("未检测到死锁");}}public static void main(String[] args) {DeadlockDetector deadlockDetector = new DeadlockDetector();while (true) {deadlockDetector.detectDeadlock();try {Thread.sleep(5000); // 每隔5秒进行一次死锁检测} catch (InterruptedException e) {e.printStackTrace();}}}
}

jStack监控工具

通过JDK提供的监控工具,查看线程快照

http://www.lryc.cn/news/444386.html

相关文章:

  • Effective Java 学习笔记 方法签名设计
  • 毛利超70%、超70+智驾客户,这家AI数据训练服务商刚刚止亏
  • 本地部署高颜值某抑云音乐播放器Splayer并实现无公网IP远程听歌
  • 图像压缩编码(4)--H.26x系列视频压缩编码_2
  • JS渲染锻炼输入表单
  • proteus仿真学习(1)
  • 决策树+随机森林模型实现足球大小球让球预测软件
  • 31省市农业地图大数据
  • http请求包含什么
  • 【基础算法总结】模拟篇
  • 《深度学习》PyTorch 手写数字识别 案例解析及实现 <下>
  • 【笔记】材料分析测试:晶体学
  • 飞塔Fortigate7.4.4的DNS劫持功能
  • Unity 设计模式 之 行为型模式 -【状态模式】【观察者模式】【备忘录模式】
  • 【RabbitMQ】RabbitMQ 的概念以及使用RabbitMQ编写生产者消费者代码
  • openmv与stm32通信
  • C++ STL全面解析:六大核心组件之一----序列式容器(vector和List)(STL进阶学习)
  • 【c数据结构】OJ练习篇 帮你更深层次理解链表!(相交链表、相交链表、环形链表、环形链表之寻找环形入口点、判断链表是否是回文结构、 随机链表的复制)
  • 微软开源GraphRAG的使用教程(最全,非常详细)
  • 使用Refine构建项目(1)初始化项目
  • 【Docker】安装及使用
  • [大语言模型-论文精读] 以《黑神话:悟空》为研究案例探讨VLMs能否玩动作角色扮演游戏?
  • 提升动态数据查询效率:应对数据库成为性能瓶颈的优化方案
  • Prometheus+grafana+kafka_exporter监控kafka运行情况
  • 在vue中:style 的几种使用方式
  • 商城小程序后端开发实践中出现的问题及其解决方法
  • 阿里Arthas-Java诊断工具,基本操作和命令使用
  • Go 1.19.4 路径和目录-Day 15
  • jEasyUI 创建标签页
  • 鸿蒙HarmonyOS开发:一次开发,多端部署(界面级)天气应用案例