導航:首頁 > 編程語言 > java線程生命周期

java線程生命周期

發布時間:2022-04-26 15:59:51

java 線程有哪些狀態,這些狀態之間是如何轉化的

線程在它的生命周期中會處於各種不同的狀態:
新建、等待、就緒、運行、阻塞、死亡。
1 新建
用new語句創建的線程對象處於新建狀態,此時它和其他java對象一樣,僅被分配了內存。
2等待
當線程在new之後,並且在調用start方法前,線程處於等待狀態。
3 就緒
當一個線程對象創建後,其他線程調用它的start()方法,該線程就進入就緒狀態。處於這個狀態的線程位於Java虛擬機的可運行池中,等待cpu的使用權。
4 運行狀態
處於這個狀態的線程佔用CPU,執行程序代碼。在並發運行環境中,如果計算機只有一個CPU,那麼任何時刻只會有一個線程處於這個狀態。
只有處於就緒狀態的線程才有機會轉到運行狀態。
5 阻塞狀態
阻塞狀態是指線程因為某些原因放棄CPU,暫時停止運行。當線程處於阻塞狀態時,Java虛擬機不會給線程分配CPU,直到線程重新進入就緒狀態,它才會有機會獲得運行狀態。
6 死亡狀態
當線程執行完run()方法中的代碼,或者遇到了未捕獲的異常,就會退出run()方法,此時就進入死亡狀態,該線程結束生命周期。

由於java線程調度不是分時的,如果程序希望干預java虛擬機對線程的調度過程,從而明確地讓一個線程給另外一個線程運行的機會,可以採用以下的方法
1 調整各個線程的優先順序
2 讓處於運行狀態的線程調用Thread.sleep(long time)方法 放棄CPU 進入阻塞狀態。
sleep方法可能拋出InterruptedException
線程休眠後只能在指定的時間後使線程處於就緒狀態。(也就是等待cpu的調度)
3 讓處於運行狀態的線程調用Thread.yield()方法 只會同優先順序讓步或更高優先順序讓步,進入就緒狀態。
4 讓處於運行狀態的線程調用另一個線程的join()方法
當前運行的線程可以調用另一個線程的join()方法,當前運行的線程將轉到阻塞狀態,直至另一個線程運行結束,它才會轉到就緒狀態 從而有機會恢復運行。

通過一下幾種途徑中的一種,線程可以從被阻塞狀態到可運行狀態。
1 線程被置於睡眠狀態,且已經經過指定的毫秒數。
2 線程正在等待I/O操作的完成,且該操作已經完成。
3 線程正在等待另一個線程所持有的鎖,且另一個線程已經釋放該鎖的所有權;(也有可能等待超時。當超時發生時,線程解除阻塞。)
4 線程正在等待某個觸發條件,且另一個線程發出了信號表明條件已經發生了變化。(如果為線程的等待設置了一個超時,那麼當超時發生時該線程將解除阻塞。)
5 線程已經被掛起,且有人調用了它的resume方法。不過,由於suspend方法已經過時,resume方法也就隨之被棄用了,你不應該在自己的代碼里調用它。(現在應該用sleep取而代之。)

㈡ 基於java 線程的幾種狀態

下面是java 線程的5種狀態:

1、新建(new)

新建一個線程的對象。

2、可運行(runable)

線程對象創建後,其他線程調用該線程的start方法。或者該線程位於可運行線程池中等待被線程調用,已獲取cpu的使用權。

3、運行(running)

可運行的線程獲取了cpu的使用權,執行程序代碼

4、阻塞(block)

由於某些原因該線程放棄了cpu的使用權。停止執行。除非線程進入可運行的狀態,才會有機會獲取cpu的使用權。

(1)等待阻塞:運行中的線程執行wait方法,這時候該線程會被放入等待隊列。

(2)同步阻塞:運行中的線程獲取同步鎖,如果該同步鎖被別的線程佔用,這個線程會成被放入鎖池,等待其他線程釋放同步鎖。

(3)其他阻塞:運行的線程執行sleep或者join方法這個線程會成為阻塞狀態。當sleep超時,join等待線程終止,該線程會進入可運行狀態。

5、死亡(dead)

線程run mian 執行完畢後,或者因為某些異常產生退出了 run 方法,該線程的生命周期結束。

㈢ JAVA:線程的生命周期是什麼

1、一個線程的的生命周期可以分成兩階段:生存周期和死亡周期,其中生存周期又包括運行狀態和等待狀態.當創建一個新線程後,這個線程就進入了排隊狀態,當線程中的方法start()被調用時,線程就進入生存周期,這時它的方法isAlive()始終返回真值,直至線程進入死亡狀態。
2、有兩種方法可以實現線程,一種是擴展java.lang.Thread類,另一種是通過java.lang.Runnable介面
3、範例
import java.awt.*;
class Sample1{
public static void main(String[] args){
Mythread test1=new Mythread(1);
Mythread test2=new Mythread(2);
test1.start();
test2.start();
}
}
class Mythread extends Thread {
int id;
Mythread(int i)
{ id=i;}
public void run() {
int i=0;
while(id+i==1){
try {sleep(1000);
} catch(InterruptedException e) {}
}
System.out.println(「The id is 」+id);
}

㈣ Java開發有哪些不同的線程生命周期

當在Java程序中新建一個線程時,它的狀態是New。當調用線程的start()方法時,狀態被改變為Runnable。線程調度器會為Runnable線程池中的線程分配CPU時間並且講它們的狀態改變為Running。其他的線程狀態還有Waiting,Blocked和Dead。

㈤ JAVA中,線程有哪五個基本狀態 他們之間如何讓轉化 簡述線程周期

java中,每個線程都需經歷新生、就緒、運行、阻塞和死亡五種狀態,線程從新生到死亡的狀態變化稱為生命周期。
用new運算符和Thread類或其子類建立一個線程對象後,該線程就處於新生狀態。
新生--->就緒:通過調用start()方法
就緒--->運行:處於就緒狀態的線程一旦得到CPU,就進入運行狀態並自動調用自己的run()方法
運行--->阻塞:處於運行狀態的線程,執行sleep()方法,或等待I/O設備資源,讓出CPU並暫時中止自己運行,進入阻塞狀態
阻塞--->就緒:睡眠時間已到,或等待的I/O設備空閑下來,線程便進入就緒狀態,重新到就緒隊列中等待CPU。當再次獲得CPU時,便從原來中止位置開始繼續運行。
運行--->死亡:(1)(正常情況下)線程任務完成
(2)(非正常狀況)線程被強制性的中止,如通過執行stop()或destroy()方法來終止一個線程

㈥ JAVA中,線程有哪五個基本狀態他們之間如何讓轉化並簡述線程周期。

java中,每個線程都需經歷新生、就緒、運行、阻塞和死亡五種狀態,線程從新生到死亡的狀態變化稱為生命周期。
用new運算符和Thread類或其子類建立一個線程對象後,該線程就處於新生狀態。



㈦ java 多線程怎麼深入

並發與並行

並行,表示兩個線程同時做事情。

並發,表示一會做這個事情,一會做另一個事情,存在著調度。單核 CPU 不可能存在並行(微觀上)。

image

以上就是原生線程池創建的核心原理。除了原生線程池之外並發包還提供了簡單的創建方式,上面也說了它們是對原生線程池的一種包裝,可以讓開發者簡單快捷的創建所需要的線程池。

Executors

newSingleThreadExecutor

創建一個線程的線程池,在這個線程池中始終只有一個線程存在。如果線程池中的線程因為異常問題退出,那麼會有一個新的線程來替代它。此線程池保證所有任務的執行順序按照任務的提交順序執行。

newFixedThreadPool

創建固定大小的線程池。每次提交一個任務就創建一個線程,直到線程達到線程池的最大大小。線程池的大小一旦達到最大值就會保持不變,如果某個線程因為執行異常而結束,那麼線程池會補充一個新線程。

newCachedThreadPool

可根據實際情況,調整線程數量的線程池,線程池中的線程數量不確定,如果有空閑線程會優先選擇空閑線程,如果沒有空閑線程並且此時有任務提交會創建新的線程。在正常開發中並不推薦這個線程池,因為在極端情況下,會因為 newCachedThreadPool 創建過多線程而耗盡 CPU 和內存資源。

newScheledThreadPool

此線程池可以指定固定數量的線程來周期性的去執行。比如通過 scheleAtFixedRate 或者 scheleWithFixedDelay 來指定周期時間。

PS:另外在寫定時任務時(如果不用 Quartz 框架),最好採用這種線程池來做,因為它可以保證裡面始終是存在活的線程的。

推薦使用 ThreadPoolExecutor 方式

在阿里的 Java 開發手冊時有一條是不推薦使用 Executors 去創建,而是推薦去使用 ThreadPoolExecutor 來創建線程池。

這樣做的目的主要原因是:使用 Executors 創建線程池不會傳入核心參數,而是採用的默認值,這樣的話我們往往會忽略掉裡面參數的含義,如果業務場景要求比較苛刻的話,存在資源耗盡的風險;另外採用 ThreadPoolExecutor 的方式可以讓我們更加清楚地了解線程池的運行規則,不管是面試還是對技術成長都有莫大的好處。

改了變數,其他線程可以立即知道。保證可見性的方法有以下幾種:

  • volatile

  • 加入 volatile 關鍵字的變數在進行匯編時會多出一個 lock 前綴指令,這個前綴指令相當於一個內存屏障,內存屏障可以保證內存操作的順序。當聲明為 volatile 的變數進行寫操作時,那麼這個變數需要將數據寫到主內存中。

    由於處理器會實現緩存一致性協議,所以寫到主內存後會導致其他處理器的緩存無效,也就是線程工作內存無效,需要從主內存中重新刷新數據。

    ㈧ 輔以圖示簡述Java線程的生命周期

    //這是線程被中斷,同生命周期的代碼,希望幫到你啦!
    class MyThread implements Runnable {
    @Override
    public void run() {
    System.out.println("1、進入run()方法休眠");
    try {
    System.out.println("2、線程休眠20秒");
    Thread.sleep(20000);//這里休眠20秒
    System.out.println("3、線程正常休眠完畢");
    } catch (InterruptedException e) {
    System.out.println("4、線程發生異常休眠被中斷");
    return;//返回方法調用處
    }
    System.out.println("5、線程正常結束run()方法體");
    }
    }
    public class InterruptDemo {

    public static void main(String[] args) {
    MyThread mt = new MyThread();
    Thread t = new Thread(mt,"線程A");
    t.start();//啟動線程
    //========================================================
    try {
    Thread.sleep(2000); //保證線程至少執行2秒
    } catch (InterruptedException e) {
    e.printStackTrace();
    }
    //========================================================
    t.interrupt();//中斷線程
    }
    }

    ㈨ java線程有哪些狀態

    新生、就緒、運行、阻塞和死亡
    java中,每個線程都需經歷新生、就緒、運行、阻塞和死亡五種狀態,線程從新生到死亡的狀態變化稱為生命周期。

    ㈩ java中所有的生命周期有哪些

    新建-就緒-(阻塞)-運行--死亡

    其中當用new 創建完一個線程對象後,該線程處於新建狀態

    當線程對象調用了start()後,該線程處於就緒狀態

    如果處於就緒狀態的線程獲得CPU時間片,開始執行run方法的線程執行體,該線程處於運行狀態

    如果線程調用了sleep()或者調用了一個阻塞式IO方法等,該線程處於阻塞狀態

    如果線程的run()執行完成或者拋出一個未捕獲的異常等原因,該線程處於死亡狀態

    閱讀全文

    與java線程生命周期相關的資料

    熱點內容
    銀河麒麟字體庫存在哪個文件夾 瀏覽:956
    魔獸加丁伺服器的航空叫什麼 瀏覽:152
    花冠改裝案例哪個app多 瀏覽:515
    成績單app哪個好用 瀏覽:140
    北美程序員vs國內程序員 瀏覽:181
    php解析xml文檔 瀏覽:121
    石墨文檔APP怎麼橫屏 瀏覽:185
    牆主鋼筋加密和非加密怎麼看 瀏覽:144
    金山區文件夾封套定製 瀏覽:708
    soho程序員 瀏覽:672
    java位元組截取 瀏覽:525
    php提交作業 瀏覽:815
    房產還沒解壓可以辦理贈予嗎 瀏覽:224
    java毫秒轉分鍾 瀏覽:753
    模式識別中文pdf 瀏覽:774
    c語言平均數字編譯錯誤 瀏覽:171
    單片機算交流 瀏覽:45
    php自適應網站 瀏覽:467
    2b2t伺服器怎麼獲得許可權 瀏覽:816
    c語言javaphp 瀏覽:804