jvm---6.2、jstack分析死锁

jstack分析死锁

写一个死锁:

先写两个锁,LockA, LockB。 在LockA 的opt 方法中调用LockB 方法,在LockB 的opt 方法中调用LockA 的opt 方法

/**
 * A锁
 */
public class LockA {

    Lock lock = new ReentrantLock();

    public void opt(LockB b){
        //A 锁
        lock.lock();
        try{
            TimeUnit.SECONDS.sleep(20);
            //B 锁
            b.opt(this);

        }catch (Exception e){

        }finally {
            lock.unlock();
        }
    }
}

/**
 * B 锁
 */
public class LockB {

    Lock lock = new ReentrantLock();

    public void opt(LockA a){
        //B 锁
        lock.lock();
        try{
            TimeUnit.SECONDS.sleep(10);
            //A锁
            a.opt(this);
        }catch (Exception e){

        }finally {
            lock.unlock();
        }
    }
}

 

 

 

//测试代码:
public static void main(String[] args) {

	//构造LockA  lockB
	LockA a = new LockA();
	LockB b = new LockB();

	//线程2,先获取LockA的锁,再获取LockB的锁
	Thread t1 = new Thread(){
		@Override
		public void run() {
			a.opt(b);
		}
	};
	//设置线程名
	t1.setName("thread t1");
	t1.start();

	//线程2,先获取LockB的锁,再获取LockA的锁
	Thread t2 = new Thread(){
		@Override
		public void run() {
			b.opt(a);
		}
	};
	//设置线程名
	t2.setName("thread t2");
	t2.start();
}

使用jps 找到pid
$ jps
15592 DeadLockTest


jstack 监控线程运行情况,使用-l参数打印出锁的情况
$ jstack -l 15592

日志如下:

2018-06-11 16:51:18
Full thread dump Java HotSpot(TM) 64-Bit Server VM (25.144-b01 mixed mode):
#日志生成时间,及虚拟机信息

"DestroyJavaVM" #14 prio&

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值