java死锁分析
Java 的死锁分析
(*)JDK: 提供强大诊断工具:Thread Dump ----> 文本信息
(*)windows: ctrl+break /(fn+B) 打印锁信息
linux: kill -3 pid ----> 命令:jps 打印锁信息
Java stack information for the threads listed above:
===================================================
"Thread-1":
at ThreadB.run(DeadLock.java:68)
-waiting to lock <0x244f6498> (a java.lang.Object)
-locked <0x244f64a0> (a java.lang.Object) "Thread-0":
at ThreadA.run(DeadLock.java:41)
-waiting to lock <0x244f64a0> (a java.lang.Object)
-locked <0x244f6498> (a java.lang.Object)
Found 1 deadlock.
代码如下
public class DeadLock {
final Object lockA = new Object();final Object lockB = new Object();public static void main(String[] args) { DeadLock demo = new DeadLock(); demo.startLock();}public void startLock(){ ThreadA a= new ThreadA(lockA,lockB); ThreadB b= new ThreadB(lockA,lockB); //start threads a.start(); b.start();}
}
class ThreadA extends Thread{
private Object lockA = null;private Object lockB = null;public ThreadA(Object a, Object b){ this.lockA = a; this.lockB = b;}public void run() { synchronized (lockA) { System.out.println("*** Thread A: ***: Lock A" ); try { sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } synchronized (lockB) { System.out.println("*** Thread A: ***: Lock B" ); } } System.out.println("*** Thread A: ***: Finished" );}
}
class ThreadB extends Thread{
private Object lockA = null;private Object lockB = null;public ThreadB(Object a, Object b){ this.lockA = a; this.lockB = b;}public void run() { synchronized (lockB) { System.out.println("*** Thread B: ***: Lock B" ); try { sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } synchronized (lockA) { System.out.println("*** Thread B: ***: Lock A" ); } } System.out.println("*** Thread B: ***: Finished" );}
}
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。