04 死锁

死锁概念

A持有B,B持有A,互相等待对方释放锁,而阻塞任务

怎么防止死锁

(1)加锁顺序
线程按照一定的顺序加锁

(2)加锁时限
线程获取锁的时候加上一定的时限,超过时限则放弃对该锁的请求,并释放自己占有的锁

4 产生死锁的例子```java

/**
 * 死锁案例
 *
 * @author gaorimao
 * @since 2021-12-10
 */
public class DeadLock implements Runnable {
    public int flag = 1;
    //静态对象是类的所有对象共享的
    private static Object o1 = new Object();
    private static Object o2 = new Object();

    @Override
    public void run() {
        System.out.println("flag=" + flag);
        if (flag == 1) {
            // 锁1
            synchronized (o1) {
                try {
                    Thread.sleep(500);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                // 锁2
                synchronized (o2) {
                    System.out.println("1");
                }
            }
        }
        if (flag == 0) {
            // 锁2
            synchronized (o2) {
                try {
                    Thread.sleep(500);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                // 锁1
                synchronized (o1) {
                    System.out.println("0");
                }
            }
        }
    }

    public static void main(String[] args) {
        // 线程1,锁1,持有锁2
        DeadLock td1 = new DeadLock();
        td1.flag = 1;
        new Thread(td1).start();
        // 线程2,锁2,持有锁1
        DeadLock td2 = new DeadLock();
        td2.flag = 0;
        new Thread(td2).start();
    }
}

怎么定位死锁

(1)jps命令找出死锁类的PID

cmd下输入jps

 (2)再使用 jstack + pid查看日志

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值