zoukankan      html  css  js  c++  java
  • 死锁及定位分析

    死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力来干涉那他们都将无法推进下去,如果系统资源充足,进程的资源请求都能得到满足,死锁出现的可能性就很低,否则就会因争夺有限的资源而陷入死锁。

    例子:

    class HoldLockThread implements Runnable {
    private String lockA;
    private String lockB;

    public HoldLockThread(String lockA, String lockB) {
    this.lockA = lockA;
    this.lockB = lockB;
    }

    @Override
    public void run() {
    synchronized (lockA) {
    System.out.println(Thread.currentThread().getName()+" 自己持有:" +lockA+" 尝试获得:" +lockB);
    try {TimeUnit.SECONDS.sleep(2);} catch (InterruptedException e) {e.printStackTrace();}
    synchronized (lockB) {
    System.out.println(Thread.currentThread().getName()+" 自己持有:" +lockB+" 尝试获得:" +lockA);
    }
    }
    }
    }

    /**
    * 死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,
    * 若无外力干涉那它们都将无法推进下去
    *
    */
    public class DeadLockDemo {
    public static void main(String[] args) {
    String lockA = "lockA";
    String lockB = "lockB";
    new Thread(new HoldLockThread(lockA,lockB),"ThreadAAA").start();
    new Thread(new HoldLockThread(lockB,lockA),"ThreadBBB").start();
    }
    }
    运行结果见下图,陷入了死循环:

    怎么定位是否是死锁问题?
    第一步:打开idea的终端界面Terminal,输入 jps -l (是小写英文字母l),查看到进程编号是94700

    第二步:输入命令:  jstack 94700   ,可以看到,是死锁导致。

  • 相关阅读:
    Java学习10——package和import
    第一次作业_031502532_吴智慧
    Java学习9——面向对象
    Java学习8——类(对象)之间的关系
    Java学习7——一些注意的地方
    Java学习5——标识符和关键字
    Zookeeper集群和HBase集群
    Zookeeper、HBase的伪分布
    hive学习笔记——表的基本的操作
    hive 学习笔记——表的入门操作和命令
  • 原文地址:https://www.cnblogs.com/liuyi13535496566/p/12168284.html
Copyright © 2011-2022 走看看