public class DLTest { public static void main(String[] args) { String str = "ABC"; MyThread myThread = new MyThread(str); myThread.start(); synchronized (str){ System.out.println("str 变量的哈希值为:" + str.hashCode()); try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } try { myThread.join(); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("main is over"); } } class MyThread extends Thread{ String string; MyThread(String str){ this.string = str; } @Override public void run() { synchronized (string){ System.out.println("string 变量的哈希值为:" + string.hashCode()); } } }这段代码为什么没有死锁
时间: 2024-02-15 21:27:02 浏览: 71
Android开发笔记之:Handler Runnable与Thread的区别详解
这段代码没有死锁是因为主线程和 MyThread 线程在使用同步块时,都是在不同的时间段内使用的,因此不会产生互相等待对方释放锁的情况。
具体来说,主线程首先创建 MyThread 对象并启动了它的线程,然后获取了 str 对象的锁,并执行同步块中的代码。在这段代码执行过程中,MyThread 线程一直处于等待状态。
当主线程释放了 str 对象的锁后,MyThread 线程才获取了该锁,并执行了同步块中的代码。因为主线程已经释放了该锁,所以 MyThread 线程可以顺利地获取到该锁,避免了死锁的产生。
在主线程中,通过调用 myThread.join() 方法,主线程等待 MyThread 线程执行完毕后再结束,这也确保了 MyThread 线程在主线程结束前能够执行完毕。
阅读全文