更新時間:2020-01-16 15:53:59 來源:動力節(jié)點(diǎn) 瀏覽2441次
一、進(jìn)程
進(jìn)程是操作系統(tǒng)結(jié)構(gòu)的基礎(chǔ);是一次程序的執(zhí)行;是一個程序及其數(shù)據(jù)在處理機(jī)上順序執(zhí)行時所發(fā)生的活動。操作系統(tǒng)中,幾乎所有運(yùn)行中的任務(wù)對應(yīng)一條進(jìn)程(Process)。一個程序進(jìn)入內(nèi)存運(yùn)行,即變成一個進(jìn)程。進(jìn)程是處于運(yùn)行過程中的程序,并且具有一定獨(dú)立功能。描述進(jìn)程的有一句話非常經(jīng)典——進(jìn)程是系統(tǒng)進(jìn)行資源分配和調(diào)度的一個獨(dú)立單位。
進(jìn)程是系統(tǒng)中獨(dú)立存在的實(shí)體,擁有自己獨(dú)立的資源,擁有自己私有的地址空間。進(jìn)程的實(shí)質(zhì),就是程序在多道程序系統(tǒng)中的一次執(zhí)行過程,它是動態(tài)產(chǎn)生,動態(tài)消亡的,具有自己的生命周期和各種不同的狀態(tài)。進(jìn)程具有并發(fā)性,它可以同其他進(jìn)程一起并發(fā)執(zhí)行,按各自獨(dú)立的、不可預(yù)知的速度向前推進(jìn)。
(注意,并發(fā)性(concurrency)和并行性(parallel)是不同的。并行指的是同一時刻,多個指令在多臺處理器上同時運(yùn)行。并發(fā)指的是同一時刻只能有一條指令執(zhí)行,但多個進(jìn)程指令被快速輪換執(zhí)行,看起來就好像多個指令同時執(zhí)行一樣。)
進(jìn)程由程序、數(shù)據(jù)和進(jìn)程控制塊三部分組成。
二、線程
線程,有時被稱為輕量級進(jìn)程(Lightweight Process,LWP),是程序執(zhí)行流的最小單元。一個標(biāo)準(zhǔn)的線程由線程ID,當(dāng)前指令指針(PC),寄存器集合和堆棧組成。另外,線程是進(jìn)程中的一個實(shí)體,是被系統(tǒng)獨(dú)立調(diào)度和分派的基本單位,線程自己不擁有系統(tǒng)資源,只擁有一點(diǎn)兒在運(yùn)行中必不可少的資源,但它可與同屬一個進(jìn)程的其它線程共享進(jìn)程所擁有的全部資源。一個線程可以創(chuàng)建和撤消另一個線程,同一進(jìn)程中的多個線程之間可以并發(fā)執(zhí)行。由于線程之間的相互制約,致使線程在運(yùn)行中呈現(xiàn)出間斷性。每一個程序都至少有一個線程,若程序只有一個線程,那就是程序本身。
線程是程序中一個單一的順序控制流程。在單個程序中同時運(yùn)行多個線程完成不同的工作,稱為多線程。
在Java Web中要注意,線程是JVM級別的,在不停止的情況下,跟JVM共同消亡,就是說如果一個Web服務(wù)啟動了多個Web應(yīng)用,某個Web應(yīng)用啟動了某個線程,如果關(guān)閉這個Web應(yīng)用,線程并不會關(guān)閉,因為JVM還在運(yùn)行,所以別忘了設(shè)置Web應(yīng)用關(guān)閉時停止線程。
三、線程狀態(tài)
線程狀態(tài)圖:
Java線程具有五種基本狀態(tài)
1、新建狀態(tài)(New):當(dāng)線程對象對創(chuàng)建后,即進(jìn)入了新建狀態(tài),如:Thread t = new MyThread();
2、就緒狀態(tài)(Runnable):也被稱為“可執(zhí)行狀態(tài)”。當(dāng)調(diào)用線程對象的start()方法(t.start();),線程即進(jìn)入就緒狀態(tài)。處于就緒狀態(tài)的線程,只是說明此線程已經(jīng)做好了準(zhǔn)備,隨時等待CPU調(diào)度執(zhí)行,并不是說執(zhí)行了t.start()此線程立即就會執(zhí)行;
3、運(yùn)行狀態(tài)(Running):當(dāng)CPU開始調(diào)度處于就緒狀態(tài)的線程時,此時線程才得以真正執(zhí)行,即進(jìn)入到運(yùn)行狀態(tài)。注:就緒狀態(tài)是進(jìn)入到運(yùn)行狀態(tài)的唯一入口,也就是說,線程要想進(jìn)入運(yùn)行狀態(tài)執(zhí)行,首先必須處于就緒狀態(tài)中;
4、阻塞狀態(tài)(Blocked):處于運(yùn)行狀態(tài)中的線程由于某種原因,暫時放棄對CPU的使用權(quán),停止執(zhí)行,此時進(jìn)入阻塞狀態(tài),直到其進(jìn)入到就緒狀態(tài),才有機(jī)會再次被CPU調(diào)用以進(jìn)入到運(yùn)行狀態(tài)。根據(jù)阻塞產(chǎn)生的原因不同,阻塞狀態(tài)又可以分為三種:
(1)等待阻塞 -- 運(yùn)行狀態(tài)中的線程執(zhí)行wait()方法,使本線程進(jìn)入到等待阻塞狀態(tài);
(2)同步阻塞 -- 線程在獲取synchronized同步鎖失敗(因為鎖被其它線程所占用),它會進(jìn)入同步阻塞狀態(tài);
(3)其他阻塞 -- 通過調(diào)用線程的sleep()或join()或發(fā)出了I/O請求時,線程會進(jìn)入到阻塞狀態(tài)。當(dāng)sleep()狀態(tài)超時、join()等待線程終止或者超時、或者I/O處理完畢時,線程重新轉(zhuǎn)入就緒狀態(tài)。
5、死亡狀態(tài)(Dead):線程執(zhí)行完了或者因異常退出了run()方法,該線程結(jié)束生命周期。
以上就是動力節(jié)點(diǎn)Java培訓(xùn)機(jī)構(gòu)小編介紹的“Java多線程編程基礎(chǔ)知識總結(jié)”的內(nèi)容,希望對大家有幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務(wù)。
相關(guān)內(nèi)容
java多線程的狀態(tài)轉(zhuǎn)換以及基本操作
相關(guān)閱讀
初級 202925
初級 203221
初級 202629
初級 203743