溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java線程生命周期的詳細介紹

發(fā)布時間:2020-06-15 10:42:40 來源:億速云 閱讀:122 作者:鴿子 欄目:編程語言

這篇文章將為大家詳細講解有關(guān)Java線程生命周期的詳細介紹,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

一、線程的生命周期

進程與線程一樣,都具有一定的生命周期,線程的生命周期包括四個狀態(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()查詢當前線程所在線程池的活動線程數(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é)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI