关于Deadlock的例子

本文通过两个具体的Java代码示例,展示了如何发生死锁及如何避免。首先介绍了一个导致死锁的程序,其中两个线程分别尝试以不同的顺序锁定两个资源,导致双方都在等待对方释放锁,从而陷入死锁状态。随后给出了修改后的代码,通过调整锁的获取顺序避免了死锁的发生。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

发生Deadlock的情况

public class TestDeadlockExample1 {  
  public static void main(String[] args) {  
    final String resource1 = "ratan jaiswal";  
    final String resource2 = "vimal jaiswal";  
    // t1 tries to lock resource1 then resource2  
    Thread t1 = new Thread() {  
      public void run() {  
          synchronized (resource1) {  
           System.out.println("Thread 1: locked resource 1");  

           try { Thread.sleep(100);} catch (Exception e) {}  

           synchronized (resource2) {  
            System.out.println("Thread 1: locked resource 2");  
           }  
         }  
      }  
    };  

    // t2 tries to lock resource2 then resource1  
    Thread t2 = new Thread() {  
      public void run() {  
        synchronized (resource2) {  
          System.out.println("Thread 2: locked resource 2");  

          try { Thread.sleep(100);} catch (Exception e) {}  

          synchronized (resource1) {  
            System.out.println("Thread 2: locked resource 1");  
          }  
        }  
      }  
    };  


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

输出结果:

Thread 1: locked resource 1
Thread 2: locked resource 2

叙述:发生了死锁。Thread1先获得resource1的lock,Thread2先获得resource2的lock。在Thread1还没有将resource1的lock交出时,又等着去获得resource2的lock(因为关于resource2的语句嵌套在关于resource1的语句中);同样,在Thread2还没有将resource2的lock交出时,又等着去获得resource1的lock(因为关于resource1的语句嵌套在关于resource2的语句中)。因此陷入了Deadlock

如果这样做,就不会发生Deadlock了:
此代码并不是预防死锁的代码,只是上面的一个例子的对照

public class TestDeadLockExample1 {  
      public static void main(String[] args) {  
        final String resource1 = "ratan jaiswal";  
        final String resource2 = "vimal jaiswal";  
        // t1 tries to lock resource1 then resource2  
        Thread t1 = new Thread() {  
          public void run() {  
              synchronized (resource1) {  
               System.out.println("Thread 1: locked resource 1");  
               try { Thread.sleep(100);} catch (Exception e) {}  
              }
              synchronized (resource2) {  
                    System.out.println("Thread 1: locked resource 2");  
                   }  
          }  
        };  

        // t2 tries to lock resource2 then resource1  
        Thread t2 = new Thread() {  
          public void run() {  
            synchronized (resource2) {  
              System.out.println("Thread 2: locked resource 2");  
              try { Thread.sleep(100);} catch (Exception e) {}  
            }
            synchronized (resource1) {  
                System.out.println("Thread 2: locked resource 1");  
              }  
          }  
        };  

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

      }  
    }  

输出结果:

Thread 1: locked resource 1
Thread 2: locked resource 2
Thread 2: locked resource 1
Thread 1: locked resource 2

此时,获得lock1的前提并不是获得lock2了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值