死锁案例及查看方法
来源:互联网 发布:最好的中国象棋软件 编辑:程序博客网 时间:2024/05/29 08:37
死锁:指的是两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,如果无外力作用,它们都将无法推进。
* @function 死锁案例 */public class DeadLockDemo {private static String A="A";private static String B="B";public static void main(String[] args) {// TODO Auto-generated method stubnew DeadLockDemo().deadLock();}private void deadLock(){Thread t1=new Thread(new Runnable(){public void run(){synchronized(A){try{Thread.currentThread().sleep(2000);}catch(Exception e){e.printStackTrace();}synchronized(B){System.out.println("1");}}}});Thread t2=new Thread(new Runnable(){public void run(){synchronized(B){synchronized(A){System.out.println("2");}}}});t1.start();t2.start();}}
打开cmd,输入jps命令,jps可以直接显示java进程的pid,可以看到DeadLockDemo的id为15784;再输入jstack15784命令,找到代码相关的线程的信息,在信息的末尾可以看到第二张图的信息:可以从信息发现这两个线程都在等对方释放锁,进入死锁状态
阅读全文
0 0
- 死锁案例及查看方法
- Oracle查看及解决死锁
- 数据库死锁查看及解决办法
- postgreSql查看死锁及解决办法
- 一个多线程死锁案例,如何避免及解决死锁问题?
- 死锁案例
- 死锁原因及预防方法
- oracle查看死锁和处理方法
- Java线程死锁查看分析方法
- Java线程死锁查看分析方法
- 查看死锁
- 查看死锁
- 查看死锁
- 查看死锁
- 查看死锁
- 查看死锁:
- SQLServer 检查死锁及阻塞,解决死锁及阻塞,查看数据库所有锁信息.
- MySQL死锁分析及解决的方法
- zookeeper集群部署后启动报错ZooKeeper JMX enabled by default...解决方案二
- 2017多校-10
- Tree POJ
- 排序算法(1)—冒泡排序
- 网关、路由器、网桥,中继器,交换机的区别
- 死锁案例及查看方法
- 用JAVA写贪吃蛇游戏 超详细注释及原理讲解
- 算法系列——从尾到头打印链表(剑指offer)
- 2016-2017 ACM-ICPC, NEERC, Moscow Subregional Contest K. Knights of the Old Republic kruskal
- 【面试】HTTP中Get与Post的区别
- AS3 前端网页游戏系统的开发
- (十一)Spring Boot整合Mybatis使用druid实现多数据源自动切换
- HDU 6172 Array Challenge 找规律+矩阵快速幂
- SCARA 机器人概述