java如何定位锁

首先使用jconsole连接上应用


点击死锁 然后会出现两个线程


也就是这两个线程出现了死锁
然后再使用jstack进行分析具体是哪一行代码出现死锁

jstack -l 18404



这个就写的比较明白了 线程1 卡在 DeadLock 43行代码 而 线程 2卡在DeadLock 56行代码
最后附上我测试使用的java DeadLock代码

package tt;

/**
 * Created by zh on 2017/9/18.
 */
public class DeadLock {

    public static void main(String[] args) {
        Container container = new Container();
        Runnable r = () -> {
            try {
                container.method1();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        };

        Runnable r2 = () -> {
            try {
                container.method2();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        };

        new Thread(r,"线程1").start();
        new Thread(r2,"线程2").start();

    }
}

class Container{

    private Object lock1 = new Object();
    private Object lock2 = new Object();

    public void method1() throws InterruptedException {
        while (true){
            synchronized (lock1){
                //暂停1秒
                Thread.sleep(1000);
                synchronized (lock2){
                    System.out.println("method1正在执行");
                }
            }
        }

    }

    public void method2() throws InterruptedException {
       while (true){
           synchronized (lock2){
               //暂停1秒
               Thread.sleep(5);
               synchronized (lock1){
                   System.out.println("method2正在执行");
               }
           }
       }
    }


}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值