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" );
}

}