Java線程的生命周期的詳解
成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設、高性價比潤州網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式潤州網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設找我們,業(yè)務覆蓋潤州地區(qū)。費用合理售后完善,十年實體公司更值得信賴。對于多線程編程而言,理解線程的生命周期非常重要,本文就針對這一點進行講解。
一、線程的狀態(tài)
線程的存在有幾種不同的狀態(tài),如下:
1、New狀態(tài)
New狀態(tài)是線程已經(jīng)被創(chuàng)建,但是還未開始運行的狀態(tài)。此狀態(tài)通過調(diào)用線程的start()方法可讓線程運行。
2、Runnable狀態(tài)
Runnable狀態(tài)可稱為準備運行狀態(tài),也可稱為隊列,此狀態(tài)通過調(diào)用線程的start()方法可讓線程運行。
線程調(diào)度器決定要運行哪些線程,且線程運行多久。
3、Running狀態(tài)
如果一個線程正在執(zhí)行中,那么它處于Running狀態(tài)。
4、Dead狀態(tài)
一旦某個線程進入了Dead狀態(tài),那么它就再也不能運行了。
5、Non runnable狀態(tài)
某個正在運行的線程可轉(zhuǎn)變到Non runnable狀態(tài),這取決于運行情況。
某個線程還可以一直保持Non runnable狀態(tài),直到滿足的條件出現(xiàn)。
某個Non runnable狀態(tài)的線程不能直接跳轉(zhuǎn)到運行狀態(tài),而是必須先轉(zhuǎn)變?yōu)镽unnable狀態(tài)。
睡眠Sleeping:線程睡眠指定的時間。
I/O阻塞:線程等待,直到阻塞操作的完成。
join阻塞:線程等待,直到另一個線程執(zhí)行完成。
等待通知:線程等待另一個線程的通知。
鎖機制阻塞:線程等待,直到指定的鎖被釋放,獲得鎖。
Java虛擬機JVM根據(jù)線程的優(yōu)先級和調(diào)度原則執(zhí)行線程。
二、線程調(diào)度器
在JVM中,線程調(diào)度器的實現(xiàn)通?;谝韵聝煞N策略:
線程調(diào)度器的實現(xiàn)與平臺無關(guān),因此線程的調(diào)度是不可預測的。
三、線程的優(yōu)先級
JVM會為每一個新創(chuàng)建的線程分配一個優(yōu)先級。
為了保存這些值,線程類有三個相應的變量:
一個線程首先會繼承其父線程的優(yōu)先級,每一個線程默認的優(yōu)先級是5級(Normal優(yōu)先級),主線程的默認優(yōu)先級為5級。
可以通過setPriority(int priority)方法來設置線程的優(yōu)先級。
用戶定義的線程,其默認的線程名為Thread+序號,序號從0開始,比如第一個線程為Thread0。
線程名可以通過setName(String name)方法進行設置,可使用getName()方法獲得線程的名字。
實例
下面看一個例子:
package demo.ch; public class UserThread extends Thread { UserThread() { super(); } UserThread(String name) { super(name); } public void run() { System.out.println("thread started running.."); } public static void main(String[] args) { UserThread thread1 = new UserThread("Thread1"); UserThread thread2 = new UserThread("Thread2"); System.out.println("Thread 1 initial name and priority"); System.out.println("name:" + thread1.getName()); System.out.println("priority:" + thread1.getPriority()); System.out.println("Thread 2 initial name and priority"); System.out.println("name:" + thread2.getName()); System.out.println("priority:" + thread2.getPriority()); System.out.println(""); thread1.setPriority(6); thread2.setPriority(9); System.out.println("Thread 1 initial name and priority"); System.out.println("name:" + thread1.getName()); System.out.println("priority:" + thread1.getPriority()); System.out.println("Thread 2 initial name and priority"); System.out.println("name:" + thread2.getName()); System.out.println("priority:" + thread2.getPriority()); System.out.println(""); thread1.start(); thread2.start(); for(int i=0; i<5; i++) System.out.println("main method i value: " + i); } }