1. 程式人生 > >Java高級-解析Java中的多線程機制

Java高級-解析Java中的多線程機制

分配 優先 恢復 需要 java應用程序 成員變量 函數 分布式 方法

線程的狀態控制

在這裏需要明確的是:無論 采用繼承Thread類還是實現Runnable接口來實現應用程序的多線程能力,都需要在該類中定義用於完成實際功能的run方法,這個run方法稱為 線程體(Thread Body)。按照線程體在計算機系統內存中的狀態不同,可以將線程分為創建、就緒、運行、睡眠、掛起和死亡等類型。這些線程狀態類型下線程的特征為:

創建狀態:當利用new關鍵字創建線程對象實例後,它僅僅作為一個對象實例存在,JVM沒有為其分配CPU時間片等線程運行資源;

就緒狀態:在處於創建狀態的線程中調用start方法將線程的狀態轉換為就緒狀態。這時,線程已經得到除CPU時間之外的其它系統資源,只等JVM的線程調度器按照線程的優先級對該線程進行調度,從而使該線程擁有能夠獲得CPU時間片的機會。

睡眠狀態:在線程運行過程中可以調用sleep方法並在方法參數中指定線程的睡眠時間將線程狀態轉換為睡眠狀態。這時,該線程在不釋放占用資源的情況下停止運行指定的睡眠時間。時間到達後,線程重新由JVM線程調度器進行調度和管理。

掛起狀態:可以通過調用suspend方法將線程的狀態轉換為掛起狀態。這時,線程將釋放占用的所有資源,由JVM調度轉入臨時存儲空間,直至應用程序調用resume方法恢復線程運行。

死亡狀態:當線程體運行結束或者調用線程對象的stop方法後線程將終止運行,由JVM收回線程占用的資源。

在Java線程類中分別定義了相應的方法,用於在應用程序中對線程狀態進行控制和管理。

線程的調度

線程調用的意義在於JVM應對運行的多個線程進行系統級的協調,以避免多個線程爭用有限資源而導致應用系統死機或者崩潰。

為 了線程對於操作系統和用戶的重要性區分開,Java定義了線程的優先級策略。Java將線程的優先級分為10個等級,分別用1-10之間的數字表示。數字 越大表明線程的級別越高。相應地,在Thread類中定義了表示線程最低、最高和普通優先級的成員變量MIN_PRIORITY、 MAX_PRIORITY和NORMAL_PRIORITY,代表的優先級等級分別為1、10和5。當一個線程對象被創建時,其默認的線程優先級是5。

為了控制線程的運行策略,Java定義了線程調度器來監控系統中處於就緒狀態的所有線程。線程調度器按照線程的優先級決定那個線程投入處 理器運行。在多個線程處於就緒狀態的條件下,具有高優先級的線程會在低優先級線程之前得到執行。線程調度器同樣采用"搶占式"策略來調度線程執行,即當前 線程執行過程中有較高優先級的線程進入就緒狀態,則高優先級的線程立即被調度執行。具有相同優先級的所有線程采用輪轉的方式來共同分配CPU時間片。

在應用程序中設置線程優先級的方法很簡單,在創建線程對象之後可以調用線程對象的setPriority方法改變該線程的運行優先級,同樣可以調用getPriority方法獲取當前線程的優先級。

在Java 中比較特殊的線程是被稱為守護(Daemon)線程的低級別線程。這個線程具有最低的優先級,用於為系統中的其它對象和線程提供服務。將一個用戶線程設置 為守護線程的方式是在線程對象創建之前調用線程對象的setDaemon方法。典型的守護線程例子是JVM中的系統資源自動回收線程,它始終在低級別的狀 態中運行,用於實時監控和管理系統中的可回收資源。

線程分組管理

Java定義 了在多線程運行系統中的線程組(ThreadGroup)對象,用於實現按照特定功能對線程進行集中式分組管理。用戶創建的每個線程均屬於某線程組,這個 線程組可以在線程創建時指定,也可以不指定線程組以使該線程處於默認的線程組之中。但是,一旦線程加入某線程組,該線程就一直存在於該線程組中直至線程死 亡,不能在中途改變線程所屬的線程組。

當Java的Application應用程序運行時,JVM創建名稱為main的線程組。除非 單獨指定,在該應用程序中創建的線程均屬於main線程組。在main線程組中可以創建其它名稱的線程組並將其它線程加入到該線程組中,依此類推,構成線 程和線程組之間的樹型管理和繼承關系。

與線程類似,可以針對線程組對象進行線程組的調度、狀態管理以及優先級設置等。在對線程組進行管理過程中,加入到某線程組中的所有線程均被看作統一的對象。

小結





本文針對Java平臺中線程的性質和應用程序的多線程策略進行了分析和講解。與其它操作系統環境不同,Java運行環境中的線程類似於多用戶、多任務操作系統環境下的進程,但在進程和線程的運行及創建方式等方面,進程與Java線程具有明顯區別。

Unix 操作系統環境下,應用程序可以利用fork函數創建子進程,但子進程與該應用程序進程擁有獨立的地址空間、系統資源和代碼執行單元,並且進程的調度是由操 作系統來完成的,使得在應用進程之間進行通信和線程協調相對復雜。而Java應用程序中的多線程則是共享同一應用系統資源的多個並行代碼執行體,線程之間 的通信和協調方法相對簡單。

可以說:Java語言對應用程序多線程能力的支持增強了Java作為網絡程序設計語言的優勢,為實現分布式應用系統中多客戶端的並發訪問以及提高服務器的響應效率奠定堅實基礎。

Java高級-解析Java中的多線程機制