這篇文章將為大家詳細講解有關Java線程生命周期的詳細介紹,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
同安網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)建站!從網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、APP開發(fā)、響應式網(wǎng)站開發(fā)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)建站從2013年開始到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設就選創(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的使用權;
2)創(chuàng)建完畢線程對象后,啟動該線程對象的是start()方法,而不是run()方法。
2.就緒狀態(tài)
1)是指一個線程對象使用start()方法后到運行完run()方法的這個階段,線程一旦就進入就緒階段,Java虛擬機為該線程創(chuàng)建方法的調(diào)用棧和計數(shù)器等;
2)在某一單位時間(時間片)內(nèi),CPU只能運行一個線程,一但一個線程擁有了CPU的使用權,則該線程也可稱為正在運行狀態(tài);
3)凡是處于就緒狀態(tài)的線程都被視為活動的,可以使用isAlive()方法測試線程是否處于就緒狀態(tài),使用activeCount()查詢當前線程所在線程池的活動線程數(shù);
4)處于就緒狀態(tài)的線程并不是運行狀態(tài),在以前的計算機很多都是單處理器的,要在同一時刻運行所有處于就緒狀態(tài)的線程是不可能的,Java通過一些調(diào)度算法來保證這些線程共享使用處理器(如時間片輪轉算法、獨占算法等)。
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(); } } }
下面是部分運行結果截圖:
可以看到如果同時啟動的線程越多,會導致每個線程的耗時越長。
關于Java線程生命周期的詳細介紹就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
新聞標題:Java線程生命周期的詳細介紹
文章鏈接:http://aaarwkj.com/article16/gpjsdg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設、用戶體驗、軟件開發(fā)、網(wǎng)站內(nèi)鏈、小程序開發(fā)、網(wǎng)站排名
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)