
Java 教程
- Java - 首頁
- Java - 概述
- Java - 歷史
- Java - 特性
- Java vs. C++
- JVM - Java虛擬機器
- Java - JDK vs JRE vs JVM
- Java - Hello World 程式
- Java - 環境搭建
- Java - 基本語法
- Java - 變數型別
- Java - 資料型別
- Java - 型別轉換
- Java - Unicode 系統
- Java - 基本運算子
- Java - 註釋
- Java - 使用者輸入
- Java - 日期和時間
Java 控制語句
- Java - 迴圈控制
- Java - 決策制定
- Java - if-else
- Java - switch
- Java - for 迴圈
- Java - for-each 迴圈
- Java - while 迴圈
- Java - do-while 迴圈
- Java - break
- Java - continue
面向物件程式設計
- Java - 面向物件程式設計概念
- Java - 物件和類
- Java - 類屬性
- Java - 類方法
- Java - 方法
- Java - 變數作用域
- Java - 建構函式
- Java - 訪問修飾符
- Java - 繼承
- Java - 聚合
- Java - 多型
- Java - 重寫
- Java - 方法過載
- Java - 動態繫結
- Java - 靜態繫結
- Java - 例項初始化塊
- Java - 抽象
- Java - 封裝
- Java - 介面
- Java - 包
- Java - 內部類
- Java - 靜態類
- Java - 匿名類
- Java - 單例類
- Java - 包裝類
- Java - 列舉
- Java - 列舉建構函式
- Java - 列舉字串
Java 內建類
Java 檔案處理
Java 錯誤和異常
- Java - 異常
- Java - try-catch 塊
- Java - try-with-resources
- Java - 多重 catch 塊
- Java - 巢狀 try 塊
- Java - finally 塊
- Java - throw 異常
- Java - 異常傳播
- Java - 內建異常
- Java - 自定義異常
Java 多執行緒
- Java - 多執行緒
- Java - 執行緒生命週期
- Java - 建立執行緒
- Java - 啟動執行緒
- Java - 執行緒連線
- Java - 執行緒命名
- Java - 執行緒排程器
- Java - 執行緒池
- Java - 主執行緒
- Java - 執行緒優先順序
- Java - 守護執行緒
- Java - 執行緒組
- Java - 關閉鉤子
Java 同步
Java 網路程式設計
- Java - 網路程式設計
- Java - 套接字程式設計
- Java - URL 處理
- Java - URL 類
- Java - URLConnection 類
- Java - HttpURLConnection 類
- Java - Socket 類
- Java - 泛型
Java 集合
Java 介面
Java 資料結構
Java 集合演算法
高階 Java
- Java - 命令列引數
- Java - Lambda 表示式
- Java - 傳送郵件
- Java - Applet 基礎
- Java - Javadoc 註釋
- Java - 自動裝箱和拆箱
- Java - 檔案不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 檔案
- Java - 私有介面方法
- Java - 內部類菱形運算子
- Java - 多解析度影像 API
- Java - 集合工廠方法
- Java - 模組系統
- Java - Nashorn JavaScript
- Java - Optional 類
- Java - 方法引用
- Java - 函式式介面
- Java - 預設方法
- Java - Base64 編碼解碼
- Java - switch 表示式
- Java - Teeing 收集器
- Java - 微基準測試
- Java - 文字塊
- Java - 動態 CDS 歸檔
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指標異常
- Java - 打包工具
- Java - 密封類
- Java - 記錄類
- Java - 隱藏類
- Java - 模式匹配
- Java - 簡潔數字格式化
- Java - 垃圾收集
- Java - JIT 編譯器
Java 雜項
- Java - 遞迴
- Java - 正則表示式
- Java - 序列化
- Java - 字串
- Java - Process API改進
- Java - Stream API改進
- Java - 增強的 @Deprecated 註解
- Java - CompletableFuture API改進
- Java - 流
- Java - 日期時間 API
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java APIs 和框架
Java 類引用
- Java - Scanner
- Java - 陣列
- Java - 字串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用資源
Java - 執行緒生命週期
Java中執行緒的生命週期
Java 中執行緒的生命週期是指執行緒經歷的各種狀態。例如,執行緒誕生、啟動、執行,然後死亡。Thread 類定義了執行緒的生命週期和各種狀態。
Java 執行緒生命週期流程圖
下圖顯示了執行緒的完整生命週期。

Java中執行緒生命週期的狀態
以下是生命週期的階段:
新建 - 新執行緒從新建狀態開始其生命週期。它保持在此狀態,直到程式啟動執行緒。它也稱為新生執行緒。
可執行 - 新生執行緒啟動後,執行緒變為可執行狀態。處於此狀態的執行緒被認為正在執行其任務。
等待 - 有時,當執行緒等待另一個執行緒執行任務時,執行緒會轉換到等待狀態。只有當另一個執行緒發出訊號讓等待執行緒繼續執行時,執行緒才會轉換回可執行狀態。
計時等待 - 可執行執行緒可以進入計時等待狀態,持續指定的間隔時間。處於此狀態的執行緒在其時間間隔到期或其等待的事件發生時轉換回可執行狀態。
終止(死亡) - 可執行執行緒在完成其任務或以其他方式終止時進入終止狀態。
演示執行緒狀態的 Java 示例
在這個例子中,我們透過擴充套件 Thread 類來建立兩個執行緒。我們列印執行緒的每個狀態。當建立執行緒物件時,其狀態為 NEW;當呼叫start() 方法時,狀態為 START;當呼叫run() 方法時,狀態為 RUNNING;當執行緒完成 run() 方法的處理後,它進入 DEAD 狀態。
package com.tutorialspoint; class ThreadDemo extends Thread { private Thread t; private String threadName; ThreadDemo( String name) { threadName = name; System.out.println("Thread: " + threadName + ", " + "State: New"); } public void run() { System.out.println("Thread: " + threadName + ", " + "State: Running"); for(int i = 4; i > 0; i--) { System.out.println("Thread: " + threadName + ", " + i); } System.out.println("Thread: " + threadName + ", " + "State: Dead"); } public void start () { System.out.println("Thread: " + threadName + ", " + "State: Start"); if (t == null) { t = new Thread (this, threadName); t.start (); } } } public class TestThread { public static void main(String args[]) { ThreadDemo thread1 = new ThreadDemo( "Thread-1"); ThreadDemo thread2 = new ThreadDemo( "Thread-2"); thread1.start(); thread2.start(); } }
輸出
Thread: Thread-1, State: New Thread: Thread-2, State: New Thread: Thread-1, State: Start Thread: Thread-2, State: Start Thread: Thread-1, State: Running Thread: Thread-2, State: Running Thread: Thread-2, 4 Thread: Thread-2, 3 Thread: Thread-2, 2 Thread: Thread-2, 1 Thread: Thread-2, State: Dead Thread: Thread-1, 4 Thread: Thread-1, 3 Thread: Thread-1, 2 Thread: Thread-1, 1 Thread: Thread-1, State: Dead
更多關於執行緒生命週期和狀態的示例
示例 1
在這個例子中,我們使用sleep() 方法來引入一些處理延遲,並展示使用執行緒的並行處理。我們透過擴充套件 Thread 類來建立兩個執行緒。我們列印執行緒的每個狀態。當建立執行緒物件時,其狀態為 NEW;當呼叫 start() 方法時,狀態為 START;當呼叫 run() 方法時,狀態為 RUNNING;如果呼叫 sleep(),則執行緒進入 WAITING 狀態;當執行緒完成 run() 方法的處理後,它進入 DEAD 狀態。
package com.tutorialspoint; class ThreadDemo extends Thread { private Thread t; private String threadName; ThreadDemo( String name) { threadName = name; System.out.println("Thread: " + threadName + ", " + "State: New"); } public void run() { System.out.println("Thread: " + threadName + ", " + "State: Running"); try { for(int i = 4; i > 0; i--) { System.out.println("Thread: " + threadName + ", " + i); // Let the thread sleep for a while. System.out.println("Thread: " + threadName + ", " + "State: Waiting"); Thread.sleep(50); } } catch (InterruptedException e) { System.out.println("Thread " + threadName + " interrupted."); } System.out.println("Thread: " + threadName + ", " + "State: Dead"); } public void start () { System.out.println("Thread: " + threadName + ", " + "State: Start"); if (t == null) { t = new Thread (this, threadName); t.start (); } } } public class TestThread { public static void main(String args[]) { ThreadDemo thread1 = new ThreadDemo( "Thread-1"); ThreadDemo thread2 = new ThreadDemo( "Thread-2"); thread1.start(); thread2.start(); } }
輸出
Thread: Thread-1, State: New Thread: Thread-2, State: New Thread: Thread-1, State: Start Thread: Thread-2, State: Start Thread: Thread-1, State: Running Thread: Thread-1, 4 Thread: Thread-1, State: Waiting Thread: Thread-2, State: Running Thread: Thread-2, 4 Thread: Thread-2, State: Waiting Thread: Thread-1, 3 Thread: Thread-2, 3 Thread: Thread-2, State: Waiting Thread: Thread-1, State: Waiting Thread: Thread-2, 2 Thread: Thread-1, 2 Thread: Thread-1, State: Waiting Thread: Thread-2, State: Waiting Thread: Thread-2, 1 Thread: Thread-2, State: Waiting Thread: Thread-1, 1 Thread: Thread-1, State: Waiting Thread: Thread-2, State: Dead Thread: Thread-1, State: Dead
示例 2
在這個例子中,我們透過實現 Runnable 類來建立兩個執行緒。我們列印執行緒的每個狀態。當建立執行緒物件時,其狀態為 NEW;當呼叫 start() 方法時,狀態為 START;當呼叫 run() 方法時,狀態為 RUNNING;如果呼叫 sleep(),則執行緒進入 WAITING 狀態;當執行緒完成 run() 方法的處理後,它進入 DEAD 狀態。
package com.tutorialspoint; class ThreadDemo implements Runnable { private Thread t; private String threadName; ThreadDemo( String name) { threadName = name; System.out.println("Thread: " + threadName + ", " + "State: New"); } public void run() { System.out.println("Thread: " + threadName + ", " + "State: Running"); try { for(int i = 4; i > 0; i--) { System.out.println("Thread: " + threadName + ", " + i); // Let the thread sleep for a while. System.out.println("Thread: " + threadName + ", " + "State: Waiting"); Thread.sleep(50); } } catch (InterruptedException e) { System.out.println("Thread " + threadName + " interrupted."); } System.out.println("Thread: " + threadName + ", " + "State: Dead"); } public void start () { System.out.println("Thread: " + threadName + ", " + "State: Start"); if (t == null) { t = new Thread (this, threadName); t.start (); } } } public class TestThread { public static void main(String args[]) { ThreadDemo thread1 = new ThreadDemo( "Thread-1"); ThreadDemo thread2 = new ThreadDemo( "Thread-2"); thread1.start(); thread2.start(); } }
輸出
Thread: Thread-1, State: New Thread: Thread-2, State: New Thread: Thread-1, State: Start Thread: Thread-2, State: Start Thread: Thread-1, State: Running Thread: Thread-1, 4 Thread: Thread-1, State: Waiting Thread: Thread-2, State: Running Thread: Thread-2, 4 Thread: Thread-2, State: Waiting Thread: Thread-1, 3 Thread: Thread-2, 3 Thread: Thread-2, State: Waiting Thread: Thread-1, State: Waiting Thread: Thread-2, 2 Thread: Thread-1, 2 Thread: Thread-1, State: Waiting Thread: Thread-2, State: Waiting Thread: Thread-2, 1 Thread: Thread-2, State: Waiting Thread: Thread-1, 1 Thread: Thread-1, State: Waiting Thread: Thread-2, State: Dead Thread: Thread-1, State: Dead