在看Thread.join()的源码时,发现实现是在一个等待通知的经典范式下实现的join方法。在等待过程中使用的wait(0),忽然想到wait()是如何实现的,为什么wait方法需要先获得锁,再使用锁调用wait方法。
这其实也是一种通信机制,通过线程之间共享内存的通信机制。每个对象都会有一个等待集合和阻塞集合,而存储的就是采用此对象作为锁调用wait()方法的线程对象和因竞争锁而阻塞的线程对象。那么回到这个问题,先获得锁再用锁调用wait()方法那么当前线程对象也就存储在了wait集合里。那么,在调用notify和notify唤醒线程时也就知道去唤醒哪个线程,所以在调用这三个方法时都需要获得当前对象的锁,因为线程之间是通过这个对象进行通信的。