线程通信的方式
- volatile
- 等待/通知机制
- join方式
- threadLocal
1 volatile的理解
2 等待/通知机制的理解
等待通知机制 是基于wait和notify方法来实现的,在一个线程内调用该线程锁对象的wait方法,线程将进入等待队列进行等待直到被通知或者被唤醒。
对于wait()和notify()的理解,还是要从jdk官方文档中开始,在Object类方法中有:
void notify() :唤醒在此对象监视器上等待的单个线程。
void notifyAll() :唤醒在此对象监视器上等待的所有线程。
void wait( ) :导致当前的线程等待,直到其他线程调用此对象的notify( ) 方法或 notifyAll( ) 方法。
void wait(long timeout) :导致当前的线程等待,直到其他线程调用此对象的notify() 方法或 notifyAll() 方法,或者指定的时间过完。
3 join方式的理解
在很多情况下,主线程创建并启动子线程,如果子线程中要进行大量的耗时运算,主线程往往将早于子线程结束之前结束。这时,如果主线程想等待子线程执行完成之后再结束,比如子线程处理一个数据,主线程要取得这个数据中的值,就要用到join()方法了。
方法join的作用是使所属的线程对象x正常执行run()方法中的任务,而使当前线程z进行无限期的阻塞,等待线程x销毁后再继续执行线程z后面的代码。