java 线程的几种状态

文章内索引
[显示]

java thread的运行周期中, 有几种状态, 在 java.lang.Thread.State 中有详细定义和说明:

NEW 状态是指线程刚创建, 尚未启动

RUNNABLE 状态是线程正在正常运行中, 当然可能会有某种耗时计算/IO等待的操作/CPU时间片切换等, 这个状态下发生的等待一般是其他系统资源, 而不是锁, Sleep等

BLOCKED  这个状态下, 是在多个线程有同步操作的场景, 比如正在等待另一个线程的synchronized 块的执行释放, 或者可重入的 synchronized块里别人调用wait() 方法, 也就是这里是线程在等待进入临界区

WAITING  这个状态下是指线程拥有了某个锁之后, 调用了他的wait方法, 等待其他线程/锁拥有者调用 notify / notifyAll 一遍该线程可以继续下一步操作, 这里要区分 BLOCKED 和 WATING 的区别, 一个是在临界点外面等待进入, 一个是在临界点里面wait等待别人notify, 线程调用了join方法 join了另外的线程的时候, 也会进入WAITING状态, 等待被他join的线程执行结束

TIMED_WAITING  这个状态就是有限的(时间限制)的WAITING, 一般出现在调用wait(long), join(long)等情况下, 另外一个线程sleep后, 也会进入TIMED_WAITING状态

TERMINATED 这个状态下表示 该线程的run方法已经执行完毕了, 基本上就等于死亡了(当时如果线程被持久持有, 可能不会被回收)

下面谈谈如何让线程进入以上几种状态:

1. NEW

这个最简单了,

输出NEW

2. RUNNABLE

 也简单, 让一个thread start, 同时代码里面不要sleep或者wait等

http://www.jiacheo.org/wp-content/uploads/2013/04/71e94764e28c7f8bbd3ef91c1c0088b4.png 第1张

3. BLOCKED

这个就必须至少两个线程以上, 然后互相等待synchronized 块

java 线程的几种状态|JAVA-翰林小院 第2张

4. WAITING,

这个需要用到生产者消费者模型, 当生产者生产过慢的时候, 消费者就会等待生产者的下一次notify

b43a3d9b67bab266ffea4537fb043bba 第3张

5.TIMED_WAITING

这个仅需要在4的基础上, 在wait方法加上一个时间参数进行限制就OK了.把4中的synchronized 块改成如下就可以了.

88d9047d8a709c2d63c695bcf58a0297 第4张

另外看stack的输出, 他叫 TIMED_WAITING(on object monitor) , 说明括号后面还有其他的情况, 比如sleep, 我们直接把t2的for循环改成sleep试试:

a37ef4c72c00e793f8b6c746d74fd4d9 第5张

看到了吧, t2的state是 TIMED_WAITING( sleeping), 而t1依然是on object monitor , 因为t1还是wait在等待t2 notify, 而t2是自己sleep
另外, join操作也是进入 on object monitor

6.TERMINATED

这个状态只要线程结束了run方法, 就会进入了…

输出:
RUNNABLE
TERMINATED
由于线程的start方法是异步启动的, 所以在其执行后立即获取状态有可能才刚进入RUN方法且还未执行完毕
废话了这么多, 了解%E


©版权声明:本文为【翰林小院】(huhanlin.com)原创文章,转载时请注明出处!