编写死锁代码并定位

本文详细解析了死锁的概念,并通过一个Java示例演示了死锁的发生过程。学习如何使用synchronized和wait/notify解决潜在的死锁问题,同时介绍了JDK工具jps和jstack在定位死锁中的应用。
摘要由CSDN通过智能技术生成

一、死锁

什么是死锁?
当两个或两个以上的线程都在等待对方执行完成自己才能继续往下执行的情况。主要是因为争夺资源而造成的一种相互等待的现象。

举个例子来说,你让你的室友帮忙带饭,然后你说“你先帮我买饭,我在给你钱”,然后你的室友说“你先给钱,我在帮你买”。然后两个人就僵持在哪里

二、死锁编码

编写一个死锁的小程序

/**
 * @author: xuzhi
 * @date: 2020/10/16 14:23
 */
public class DeadLockDemo {
    public static Object lockA=new Object();
    public static Object lockB=new Object();

    public static void main(String[] args) {
        new Thread(()->{
            synchronized (lockA){
                System.out.println(Thread.currentThread().getName()+"持有A锁,等待B锁");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                synchronized (lockB){
                    System.out.println("线程A完成");
                }
            }
        },"线程A").start();

        new Thread(()->{
            synchronized (lockB){
                System.out.println(Thread.currentThread().getName()+"持有B锁,等待A锁");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                synchronized (lockA){
                    System.out.println("线程B完成");
                }
            }
        },"线程B").start();
    }
}

三、定位死锁

如果定位死锁呢,这里我们会用到jdk1.8自带的两个小工具,一个是jps,另一个是jstack
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值