|
|
@ -1796,6 +1796,22 @@ LinkedTransferQueue(LTQ) 相比 BlockingQueue 更进一步,**生产者会一
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## 线程的状态
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- **新建(NEW)**:新创建了一个线程对象。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- **可运行(RUNNABLE)**:线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。该状态的线程位于可运行线程池中,等待被线程调度选中,获取cpu 的使用权 。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- **运行(RUNNING)**:可运行状态(runnable)的线程获得了cpu 时间片(timeslice) ,执行程序代码。
|
|
|
|
|
|
|
|
- **阻塞(BLOCKED)**:阻塞状态是指线程因为某种原因放弃了cpu 使用权,也即让出了cpu timeslice,暂时停止运行。直到线程进入可运行(runnable)状态,才有机会再次获得cpu timeslice 转到运行(running)状态。阻塞的情况分三种:
|
|
|
|
|
|
|
|
- **等待阻塞**:运行(running)的线程执行o.wait()方法,JVM会把该线程放入等待队列(waitting queue)中。
|
|
|
|
|
|
|
|
- **同步阻塞**:运行(running)的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池(lock pool)中。
|
|
|
|
|
|
|
|
- **其它阻塞**:运行(running)的线程执行Thread.sleep(long ms)或t.join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入可运行(runnable)状态。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- **死亡(DEAD)**:线程run()、main() 方法执行结束,或者因异常退出了run()方法,则该线程结束生命周期。死亡的线程不可再次复生。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## 线程生命周期
|
|
|
|
## 线程生命周期
|
|
|
|
|
|
|
|
|
|
|
|
就像生物从出生到长大、最终死亡的过程一样,线程也有自己的生命周期,在 Java 中线程的生命周期中一共有 6 种状态。
|
|
|
|
就像生物从出生到长大、最终死亡的过程一样,线程也有自己的生命周期,在 Java 中线程的生命周期中一共有 6 种状态。
|
|
|
|