代码模拟Java中产生死锁

描述

启动两个线程,设置两个线程监听对象obj1 、obj2。

  • 线程1启动的时候,先获取obj1锁,暂停1秒,然后获取obj2锁。
  • 线程2启动时,先获取obj2,再获取obj1

当线程2启动的时候获取obj2成功,然后去获取obj1的时候,obj1被线程1占用了,此时就等待。线程1秒后去获取obj2,此时obj2锁被线程2握着,产生死锁,互相无法获取。

代码

/**
 * @author yuyufeng
 * @date 2018/4/24.
 */
public class App {
    private static Object obj1 = new Object();
    private static Object obj2 = new Object();

    public static void main(String[] args) {
        new Thread(){
            @Override
            public void run() {
                synchronized (obj1){
                    try {
                        System.out.println("Thread1 obj1");
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    synchronized (obj2){
                        System.out.println("Thread1 obj2");
                    }
                }


            }
        }.start();


        new Thread(){
            @Override
            public void run() {
                synchronized (obj2){
                    System.out.println("Thread2 obj2");
                    synchronized (obj1){
                        System.out.println("Thread2 obj1");
                    }
                }
            }
        }.start();
    }
}

运行结果

猜你喜欢

转载自blog.csdn.net/qq_18860653/article/details/80194520