java死锁分析

本文通过一个具体的Java代码示例介绍了如何分析和发现Java程序中的死锁问题。使用了Thread Dump等工具来帮助诊断,并展示了如何通过打印锁信息来定位死锁发生的位置。

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

}

转载于:https://blog.51cto.com/12941821/2074622

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值