Java多线程 线程状态原理详解


本文向大家介绍Java多线程 线程状态原理详解,包括了Java多线程 线程状态原理详解的使用技巧和注意事项,需要的朋友参考一下

这篇文章主要介绍了Java多线程 线程状态原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

java.lang.Thread.State枚举定义了6种线程状态。

  • NEW: 尚未启动(start)的线程的线程状态
  • RUNNABLE: 运行状态,但线程可能正在JVM中执行,也可能在等待CPU调度
  • BLOCKED: 线程阻塞,等待监视器锁以进入同步代码块/方法
  • WAITING: 等待状态。使用以下不带超时的方式时会进入:Object.wait、Thread.join、LockSupport.park。等待状态的线程需要另一个线程激活。
  • TIMED_WAITING: 具有指定等待时间的等待状态,使用以下带超时的方式:Thread.sleep、Object.wait、Thread.join、LockSupport.parkNanos、LockSupport.parkUntil。
  • TERMINATED: 终止状态。线程正常执行完毕或者发生异常。

状态切换

状态 条件 状态 条件 状态
NEW -(启动)-》 RUNNABLE -(等待锁)-》 BLOCKED
RUNNABLE 《-(拿到锁)- BLOCKED
RUNNABLE -(等待其他线程通知)-》 WAITING
RUNNABLE 《-(收到其他线程通知)- WAITING
RUNNABLE -(有超时时间的,等待其他线程通知)-》 TIMED_WAITING
RUNNABLE 《-(收到其他线程通知,或者等待超时)- TIMED_WAITING
RUNNABLE -(执行结束)-》 TERMINATED

线程切换代码示例

/**
 * 多线程运行状态切换示例
 */
public class Demo2 {

  public static void main(String[] args) throws Exception{
    //第一种状态切换 新建->运行->终止
    System.out.println("###第一种状态切换 新建->运行->终止###");
    Thread thread1 = new Thread(()->{
      System.out.println("thread1当前状态:" + Thread.currentThread().getState());
      System.out.println("thread1执行完毕");
    });
    System.out.println("调用start之前,thread1当前状态:" + thread1.getState());
    thread1.start();
    Thread.sleep(2000L);  //等待thread1执行结束
    System.out.println("等待thread1执行结束,当前状态:" + thread1.getState());
    System.out.println();
//    thread1.start();    //此时会抛出java.lang.IllegalThreadStateException

    //第二种状态切换 新建->运行->等待->运行->终止
    System.out.println("###第二种状态切换 新建->运行->等待->运行->终止###");
    Thread thread2 = new Thread(()->{
      try {
        Thread.sleep(1500L);
      } catch (InterruptedException e) {
        e.printStackTrace();
      }
      System.out.println("thread2当前状态:" + Thread.currentThread().getState());
      System.out.println("thread2执行完毕");
    });
    System.out.println("调用start之前,thread2当前状态:" + thread2.getState());
    thread2.start();
    System.out.println("调用start之后,thread2当前状态:" + thread2.getState());
    Thread.sleep(200L);  //等待一段时间令thread2进入sleep方法
    System.out.println("调用start之后,等待200毫秒,thread2当前状态:" + thread2.getState());
    Thread.sleep(2000L);  //等待thread2执行结束
    System.out.println("等待thread2执行结束,当前状态:" + thread2.getState());
    System.out.println();

    //第三种状态切换 新建->运行->阻塞->运行->终止
    System.out.println("###第三种状态切换 新建->运行->阻塞->运行->终止###");
    Thread thread3 = new Thread(()->{
      synchronized (Demo2.class){
        System.out.println("thread3当前状态:" + Thread.currentThread().getState());
        System.out.println("thread3执行完毕");
      }
    });
    synchronized (Demo2.class){
      System.out.println("调用start之前,thread3当前状态:" + thread3.getState());
      thread3.start();
      System.out.println("调用start之后,thread3当前状态:" + thread3.getState());
      Thread.sleep(200L);
      System.out.println("等待200毫秒,thread3等待获取锁,thread3当前状态:" + thread3.getState());
    }
    Thread.sleep(1000L);    //等待thread3执行完毕
    System.out.println("等待1秒,令thread3获取锁后执行方法,thread3当前状态:" + thread3.getState());
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。