java 线程的几种状态

本文详细介绍了Java线程的不同状态,包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,并提供了每种状态的示例代码。

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, 这个最简单了,  
 
     static void NEW() {
          Thread t = new Thread ();
         System. out.println(t.getState());
    }
 
输出NEW
 
2. RUNNABLE, 也简单, 让一个thread start, 同时代码里面不要sleep或者wait等
 
   private static void RUNNABLE() {
         Thread t = new Thread(){
             
              public void run(){
                  for(int i=0; i<Integer.MAX_VALUE; i++){
                      System. out.println(i);
                 }
             }
             
         };
         
         t.start();
    }
3. BLOCKED, 这个就必须至少两个线程以上, 然后互相等待synchronized 块
          
     private static void BLOCKED() {
         
          final Object lock = new Object();
         
         Runnable run = new Runnable() {
             
              @Override
              public void run() {
                  for(int i=0; i<Integer.MAX_VALUE; i++){
                      
                       synchronized (lock) {
                          System. out.println(i);
                      }
                      
                 }
             }
         };
         
         Thread t1 = new Thread(run);
         t1.setName( “t1”);
         Thread t2 = new Thread(run);
         t2.setName( “t2”);
         
         t1.start();
         t2.start();
         
    }
这时候, 一个在RUNNABLE, 另一个就会在BLOCKED (等待另一个线程的 System.out.println.. 这是个IO操作, 属于系统资源, 不会造成WAITING等)


4. WAITING, 这个需要用到生产者消费者模型, 当生产者生产过慢的时候, 消费者就会等待生产者的下一次notify
 
     private static void WAITING() {
 
          final Object lock = new Object();
         Thread t1 = new Thread(){
              @Override
              public void run() {
                 
                  int i = 0;
                 
                  while(true ){
                       synchronized (lock) {
                           try {
                               lock.wait();
                          } catch (InterruptedException e) {
                          }
                          System. out.println(i++);
                      }
                 }
             }
         };
         
         Thread t2 = new Thread(){
              @Override
              public void run() {
                 
                  while(true ){
                       synchronized (lock) {
                           for(int i = 0; i< 10000000; i++){
                              System. out.println(i);
                          }
                          lock.notifyAll();
                      }
                      
                 }
             }
         };
         
         t1.setName( “^^t1^^”);
         t2.setName( “^^t2^^”);
         
         t1.start();
         t2.start();
    }

5. TIMED_WAITING, 这个仅需要在4的基础上, 在wait方法加上一个时间参数进行限制就OK了.
 
把4中的synchronized 块改成如下就可以了.
 
synchronized (lock) {
   try {
      lock.wait(60 * 1000L);
   } catch (InterruptedException e) {
   }
   System. out .println(i++);
 }
另外看stack的输出,  他叫 TIMED_WAITING(on  object monitor) , 说明括号后面还有其他的情况, 比如sleep, 我们直接把t2的for循环改成sleep试试:
 
synchronized (lock) {
    
    try {
          sleep(30*1000L);
    } catch (InterruptedException e) {
    }
    lock.notifyAll();
}
看到了吧, t2的state是 TIMED_WAITING( sleeping),  而t1依然是on object monitor , 因为t1还是wait在等待t2 notify, 而t2是自己sleep
 
另外, join操作也是进入 on object monitor
 
6. TERMINATED, 这个状态只要线程结束了run方法, 就会进入了…
 
    private static void TERMINATED() {
         Thread t1 = new Thread();
         t1.start();
         System. out.println(t1.getState());
          try {
             Thread. sleep(1000L);
         } catch (InterruptedException e) {
         }
         System. out.println(t1.getState());
    }
输出: 
RUNNABLE
TERMINATED
 
由于线程的start方法是异步启动的, 所以在其执行后立即获取状态有可能才刚进入RUN方法且还未执行完毕
 

### Java 线程状态种类及其特点 Java 中的线程状态由 `Thread.State` 枚举定义,共有六种主要状态。以下是每种状态的具体描述: #### 1. 新建状态 (NEW) 当一个线程被创建但尚未启动时,它处于新建状态。此时,线程仅作为一个对象存在于堆内存中,还未与底层操作系统的线程资源绑定[^3]。 ```java private void testStateNew() { Thread thread = new Thread(() -> {}); System.out.println(thread.getState()); // 输出 NEW } ``` --- #### 2. 可运行状态 (RUNNABLE) 当线程调用了 `start()` 方法后,线程进入可运行状态。这表示该线程已经准备好执行,但它不一定正在占用 CPU 资源。只有当线程调度器分配给它 CPU 时间片时,才会真正开始运行其逻辑[^2]。 - **特点**: - 此状态下,线程可能正实际运行,也可能因调度原因暂时未获得 CPU 执行权。 - 如果当前线程的时间片耗尽或者显式调用 `yield()` 方法,则会重新回到就绪队列等待下一次调度[^4]。 --- #### 3. 阻塞状态 (BLOCKED) 阻塞状态发生在多线程竞争同步锁的情况下。如果一个线程试图获取已被其他线程持有的锁,则该线程会被置于阻塞状态直到锁释放。 - **特点**: - 处于 BLOCKED 状态线程不会消耗任何 CPU 资源。 - 当锁定的对象可用时,线程将返回 RUNNABLE 状态。 --- #### 4. 等待状态 (WAITING) 当线程调用无超时参数的方法(如 `Object.wait()` 或 `Thread.join()`),则进入 WAITING 状态。这种状态下的线程需要依赖外部条件触发才能继续执行。 - **特点**: - 必须通过特定事件唤醒,例如通知机制 (`notify/notifyAll`) 或目标线程完成。 --- #### 5. 带时限等待状态 (TIMED_WAITING) 带时限等待状态类似于 WAITING,不同之处在于它具有固定的等待时间。常见的方法有 `Thread.sleep(long millis)` 和 `wait(long timeout)`。 - **特点**: - 即使没有外界干预,经过指定时间段后也会自动恢复到 RUNNABLE 状态。 - 是一种更灵活的暂停方式。 --- #### 6. 终止状态 (TERMINATED) 一旦线程完成了它的任务或由于异常退出而终止,就会进入 TERMINATED 状态。此后,该线程无法再被重用或重启。 - **特点**: - 表明线程生命周期结束。 - 不允许再次调用已终止线程的 `run()` 方法。 --- ### 总结代码示例 以下是一段用于遍历并打印所有线程状态的代码片段: ```java public class ThreadStatesExample { public static void main(String[] args) { for (Thread.State state : Thread.State.values()) { System.out.println(state); } } } ``` 上述代码能够展示所有的线程状态名称列表[^1]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值