進程和線程的理解

程序

定義:指令和數(shù)據(jù)的有序集合。是靜態(tài)的

進程

定義:進程是一個具有一定獨立功能的程序關(guān)于某個數(shù)據(jù)集合的一次運行活動。它是操作系統(tǒng)動態(tài)執(zhí)行的基本單元,在傳統(tǒng)的操作系統(tǒng)中,進程既是基本的分配單元,也是基本的執(zhí)行單元。

通俗理解:1)執(zhí)行中的程序。是動態(tài)的。程序只有在處理器執(zhí)行該程序時,才能成為一個實體,此時稱為進程。

? ? ? ? ? ? ? ? ? 2) 進程和線程都是一個時間段的描述,是CPU工作時間段的描述。操作系統(tǒng)(CPU)輪流讓各個任務(wù)交替執(zhí)行,任務(wù)1執(zhí)行0.01秒,切換到任務(wù)2,任務(wù)2執(zhí)行0.01秒,再切換到任務(wù)3,執(zhí)行0.01秒……這樣反復執(zhí)行下去。表面上看,每個任務(wù)都是交替執(zhí)行的,但是,由于CPU的執(zhí)行速度實在是太快了,我們感覺就像所有任務(wù)都在同時執(zhí)行一樣。真正的并行執(zhí)行多任務(wù)只能在多核CPU上實現(xiàn)。

進程的三個狀態(tài):就緒,阻塞,運行。(網(wǎng)上找的圖)

就緒狀態(tài):獲取除了cpu外的所有資源,只要處理器分配資源就可以馬上執(zhí)行。排隊等待cpu

運行狀態(tài):獲得cpu資源,程序開始執(zhí)行。

阻塞態(tài),當程序條件不夠時候,需要等待條件滿足時候才能執(zhí)行,如等待i/o操作


線程

一個進程包含多個線程,線程可以利用進程所擁有的資源。進程作為分配資源的基本單位,而把線程作為獨立運行和獨立調(diào)度的基本單位,由于線程比進程更小,基本上不擁有系統(tǒng)資源,故對它的調(diào)度所付出的開銷就會小得多,能更高效的提高系統(tǒng)多個程序間并發(fā)執(zhí)行的程度。同一進程中的多個線程具有相同的地址空間,所以它們間的同步和通信也易于實現(xiàn)。


參考:https://www.cnblogs.com/fuchongjundream/p/3829508.html

https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/0014319272686365ec7ceaeca33428c914edf8f70cca383000

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容