程序
定義:指令和數(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