死锁

255 阅读1分钟

1. 代码实现

class HoldLockThread implements Runnable {

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

            synchronized (lockB) {
                System.out.println(Thread.currentThread().getName()+"\t 自己持有" + lockB + "\t 尝试获取:" + lockA);
            }
        }
    }

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

/**
 * 死锁是指两个或两个以上的进程在执行过程中,因抢夺资源而造成的一种互相等待的现象
 */
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();

    }
}

2. 死锁判定

2.1 查看java进程命令

 linux: ps -ef|grep xxxx
 windows: jps -l

2.2 jstack