這篇文章將為大家詳細講解有關(guān)Java線程生命周期的詳細介紹,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
同安網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、響應(yīng)式網(wǎng)站開發(fā)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)建站從2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)建站。
一、線程的生命周期
進程與線程一樣,都具有一定的生命周期,線程的生命周期包括四個狀態(tài):創(chuàng)建狀態(tài)、就緒狀態(tài)、阻塞狀態(tài)、死亡狀態(tài)。
1.創(chuàng)建狀態(tài)
1)是指使用new實例化一個線程對象,但該線程對象還未使用start()方法啟動線程這個階段,該階段只在內(nèi)存的堆中為該對象的實例變量分配了內(nèi)存空間,但線程還無法參與搶奪CPU的使用權(quán);
2)創(chuàng)建完畢線程對象后,啟動該線程對象的是start()方法,而不是run()方法。
2.就緒狀態(tài)
1)是指一個線程對象使用start()方法后到運行完run()方法的這個階段,線程一旦就進入就緒階段,Java虛擬機為該線程創(chuàng)建方法的調(diào)用棧和計數(shù)器等;
2)在某一單位時間(時間片)內(nèi),CPU只能運行一個線程,一但一個線程擁有了CPU的使用權(quán),則該線程也可稱為正在運行狀態(tài);
3)凡是處于就緒狀態(tài)的線程都被視為活動的,可以使用isAlive()方法測試線程是否處于就緒狀態(tài),使用activeCount()查詢當(dāng)前線程所在線程池的活動線程數(shù);
4)處于就緒狀態(tài)的線程并不是運行狀態(tài),在以前的計算機很多都是單處理器的,要在同一時刻運行所有處于就緒狀態(tài)的線程是不可能的,Java通過一些調(diào)度算法來保證這些線程共享使用處理器(如時間片輪轉(zhuǎn)算法、獨占算法等)。
3.阻塞狀態(tài):
1)阻塞狀態(tài)包含四種狀態(tài)(睡眠狀態(tài)、阻塞狀態(tài)、掛起狀態(tài)、等待狀態(tài)),一般來說,阻塞狀態(tài)和就緒狀態(tài)可以相互切換的;
2)使用sleep()方法可以線程進入睡眠狀態(tài),讓其他進程得到運行機會,但是用sleep方法必須捕獲InterruptedExecption異常;
3)使用suspend方法可以掛起線程(jdk1.2后已過時)、使用wait方法使線程進入等待狀態(tài)(后面有一隨筆會專門寫)、使用I/O中斷讓線程進入阻塞狀態(tài)。
4.死亡狀態(tài):
1)一旦線程運行完run方法,線程即進入死亡狀態(tài),Java虛擬機會銷毀處于死亡狀態(tài)的線程對象所占用的系統(tǒng)資源;
2)線程執(zhí)行時遇到一個未捕獲的異常,線程會被終止并進入死亡狀態(tài);調(diào)用stop方法也可以讓線程進入死亡狀態(tài),但是容易造成死鎖,已棄用。
5.線程生命周期如下圖:
二、下面是sleep方法使線程進入睡眠狀態(tài)的案例
/** * @author: PrincessHug * @date: 2019/4/12, 9:20 * @Blog: https://www.cnblogs.com/HelloBigTable/ */ public class SleepDemo implements Runnable{ @Override public void run() { long l; for (int i=1;i<6;i++){ l = System.currentTimeMillis(); try { Thread.currentThread().sleep(5000); } catch (InterruptedException e) { e.printStackTrace(); } l = (System.currentTimeMillis() - l); System.out.println(Thread.currentThread().getName() + "線程執(zhí)行了" + i + "次,耗時" + l + "毫秒。"); } } } public class SleepDriver { public static void main(String[] args) { SleepDemo sd = new SleepDemo(); for (int i=0;i<50;i++){ new Thread(sd,i + "#").start(); } } }
下面是部分運行結(jié)果截圖:
可以看到如果同時啟動的線程越多,會導(dǎo)致每個線程的耗時越長。
關(guān)于Java線程生命周期的詳細介紹就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。