線程與進程的區(qū)別與聯(lián)系
??幾乎所有的操作系統(tǒng)都支持同時運行多個任務(wù)启妹,一個任務(wù)通常就是一個程序,每個運行中的程序就是一個進程醉旦。當(dāng)一個程序運行時饶米,內(nèi)部可能包含了多個順序執(zhí)行
流,每個程序執(zhí)行流就是一個線程髓抑。
??幾乎所有操作系統(tǒng)都支持進程的概念咙崎,所有運行中的任務(wù)通常對應(yīng)一條進程(Process)优幸。當(dāng)一個程序進入內(nèi)存運行吨拍,即變成一個進程。進程是處于運行過程中的
程序网杆,并且具有一定獨立功能羹饰,進程是系統(tǒng)進行資源分配和調(diào)度的一個獨立單位伊滋。
進程的特征:
獨立性:進程是系統(tǒng)中獨立存在的實體,它可以擁有自己獨立的資源队秩,每一個進程都擁有自己私有的地址空間笑旺。在沒有經(jīng)過進程本身允許的情況下,一個用戶進程不可以直接訪問其他進程的地址空間馍资。
動態(tài)性:進程與程序的區(qū)別在于筒主,程序只是一個靜態(tài)的指令集合,而進程是一個正在系統(tǒng)中活動的指令集合鸟蟹。在進程中加入了時間的概念乌妙。進程具有自己的生命周期和各種不同的狀態(tài),這些概念在程序中都是不具備的建钥。
并發(fā)性:多個進程可以在單個處理器上并發(fā)執(zhí)行藤韵,多個進程之間不會互相影響。
并發(fā)性(concurrency)和并行性(parallel)是兩個概念熊经,并行指在同一時刻泽艘,有多條指令在多個處理器上同時執(zhí)行;并發(fā)指在同一時刻只能有一條指令執(zhí)行镐依,但多個進程指令被快速輪換執(zhí)行匹涮,使得在宏觀上具有多個進程同時執(zhí)行的效果。
??對于一個CPU而言槐壳,它在每個時間點上只能執(zhí)行一個程序焕盟,也就是說只能運行一個進程,CPU不斷地在這些進程之間輪換執(zhí)行宏粤。那么為什么我們感覺不到任何中
斷現(xiàn)象呢脚翘?這是因為CPU的執(zhí)行速度相對我們的感覺實在是太快了(當(dāng)然,如果啟動的程序足夠多绍哎,我們依然可以感覺程序的運行速度下降)来农,所以雖然CPU在多個進程之間輪
換執(zhí)行,但我們?nèi)祟惛杏X到好像多個進程在同時執(zhí)行崇堰。
??現(xiàn)代的操作系統(tǒng)都支持多進程的并發(fā)沃于,但在具體的實現(xiàn)細節(jié)上可能因為硬件和操作系統(tǒng)的不同而采用不同的策略。比較常用的方式有:公用式的多任務(wù)操作策
略海诲,例如Window3.1和Mac OS9繁莹,目前操作系統(tǒng)大多采用效率更高的搶占式多任務(wù)策略,例如:WindowNT特幔,Window2000以及Unix/Linux等操作系統(tǒng)咨演。
??多線程擴展了多進程的概念,使得同一個進程可以同時并發(fā)處理多個任務(wù)蚯斯。線程(Thread)也被稱作輕量級進程(Lightweight Process)薄风,線程是進程的執(zhí)行單元饵较。
就像進程在操作系統(tǒng)中的地位一樣,線程在程序中是獨立的遭赂、并發(fā)的執(zhí)行流循诉。當(dāng)進程被初始化后,主線程就被創(chuàng)建了撇他。對于絕大多數(shù)的應(yīng)用程序來說茄猫,通常僅要求有一個主線
程,但我們也可以在該線程內(nèi)創(chuàng)建多條順序執(zhí)行流困肩,這些順序執(zhí)行流就是線程募疮,每條線程也是互相獨立的。
??線程是進程的組成部分僻弹,一個進程可以擁有多個線程阿浓,一個線程必須有一個父進程。線程可以擁有自己的堆棧蹋绽、自己的程序計數(shù)器和自己的局部變量芭毙,但不再擁
有系統(tǒng)資源,它與父進程的其他線程共享該進程所有的全部資源卸耘。因為多個線程共享父進程里的全部資源退敦,因此編程更加方便;但必須更加小心蚣抗,我們必須確保線程不會妨礙同
一進程里的其他線程侈百。