[23]死锁

版权声明:嘤嘤嘤,小白的东西,大牛们应该看不上吧。 https://blog.csdn.net/qq_37384180/article/details/83540574

一、产生的原因

试想一下:A和B两个人。1和2两个锁。A要拿到1锁开启一扇门后,还要再拿2锁打开另一扇门。而B也是要先拿到2锁打开一扇门,再拿1锁打开另一扇门。

情况一:A拿到了1锁后,要拿到2锁,但是2锁被B拿到了,不给A,B也没有1锁。所以两者互不相让,这就是死锁。

情况二:A拿到了1锁后,也拿到了2锁。全部开完后,B拿到了2锁,又拿到了1锁。这是和谐情况。

二、代码例子

/*锁1*/
class MyLock1 implements Runnable {
    @override
    public void run(){
        synchronized(Demo.obj1){
            System.out.println(Thread.currentThread().getName()+" obj1 lock1");
                synchronized(Demo.obj2){
                  System.out.println(Thread.currentThread().getName()+" obj2 lock2");  
            }
        }
    }
}
/*锁2*/
class MyLock2 implements Runnable{
    @override
    public void run(){
        synchronized(Demo.obj2){
            System.out.println(Thread.currentThread().getName()+" obj1 lock1");
                synchronized(Demo.obj1){
                  System.out.println(Thread.currentThread().getName()+" obj2 lock2");  
            }
        }
    }
}
/*测试类*/
class Demo{
    public static final Object obj1="obj1";
    public static final Object obj2="obj2";
    public static void main(String[] args){
        MyLock1 lock1=new MyLock1();
        MyLock2 lock2=new MyLock2();
        Thread t1=new Thread(lock1);
        Thread t2=new Thread(lock2);

        t1.start();
        t2.start();
    }
}

运行情况:

死锁

猜你喜欢

转载自blog.csdn.net/qq_37384180/article/details/83540574
23