死锁编码及定位分析

一、死锁

死锁是指两个或两个以上进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力干涉它们都将无法推进下去。

二、死锁代码案例

package com.zhang;

import java.util.concurrent.TimeUnit;

public class HoldLockThreadTest {
    public static void main(String[] args) {
        //调用实现了Runnable接口的类
        String lock001 = "lock001";
        String lock002 = "lock002";
        new Thread(new HoldLockThread(lock001,lock002),"001").start();
        new Thread(new HoldLockThread(lock002,lock001),"002").start();
    }
}

class HoldLockThread implements Runnable{
    private  String lock001;
    private  String lock002;

    public HoldLockThread(String lock001,String locak002){
        this.lock001 = lock001;
        this.lock002 = locak002;
    }

    @Override
    public void run() {
        synchronized (lock001){
            System.out.println("线程"+Thread.currentThread().getName()+"\t 自己持有锁"+lock001+"\t 尝试获取锁"+lock002);
            try {//休眠5秒,为了演示死锁效果
                TimeUnit.SECONDS.sleep(5);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            synchronized (lock002){
                System.out.println("线程"+Thread.currentThread().getName()+"\t 自己持有锁"+lock002+"\t 尝试获取锁"+lock001);
            }
        }
    }
}

执行结果
在这里插入图片描述
可以看到IEDA执行结果一直未完成(控制台没有出现Process finished with code 0)

三、死锁的定位

利用快捷键ALT+F12打开IDEA控制台cmd窗口。
输入jps -l命令定位进程号
输入jstack 进程号找到死锁报告
在这里插入图片描述
在这里插入图片描述
利用jstack命令可以看到死锁已经发生了,即lock001和lock002互相死锁。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值