死锁,Java简单示例

死锁概念

多个线程互相持有对方等待的资源,导致这些线程全都阻塞。

Java简单示例
public class App {
    private static final String LOCK_1 = "Lock1";
    private static final String LOCK_2 = "Lock2";

    public static void main(String[] args) {
        new Thread1("Thread1").start();
        new Thread2("Thread2").start();
    }

    private static class Thread1 extends Thread {
        Thread1(String name) {
            super(name);
        }

        @Override
        public void run() {
            synchronized (LOCK_1) {
                holdingLock(LOCK_1);
                sleepForSomeTime(1);
                waitingLock(LOCK_2);
                synchronized (LOCK_2) {
                    holdingLock(LOCK_2);
                }
                releaseLock(LOCK_2);
            }
            releaseLock(LOCK_1);
        }
    }


    private static class Thread2 extends Thread {
        Thread2(String name) {
            super(name);
        }

        @Override
        public void run() {
            synchronized (LOCK_2) {
                holdingLock(LOCK_2);
                waitingLock(LOCK_1);
                synchronized (LOCK_1) {
                    holdingLock(LOCK_1);
                }
                releaseLock(LOCK_1);
            }
            releaseLock(LOCK_2);
        }
    }
}

执行结果

Thread1 holding Lock1
Thread1 sleep 1s.
Thread2 holding Lock2
Thread2 waiting Lock1
Thread1 waiting Lock2
完整项目地址

https://git.coding.net/zhi-cike/dead-lock-demo.git

通过线程转存储查看是否存在死锁,当前为sun jdk使用jstack命令

利用ps查找上述代码执行线程PID,执行jstack PID,结果会直接输出到控制台
也可以输出到文件中jstack PID > dump.txt
执行结果如下
检测到死锁

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值