線程是進(jìn)程的一個(gè)實(shí)體怔檩。
進(jìn)程——資源分配的最小單位,線程——程序執(zhí)行的最小單位蓄诽。
線程進(jìn)程的區(qū)別體現(xiàn)在幾個(gè)方面:
第一:因?yàn)檫M(jìn)程擁有獨(dú)立的堆椦ρ担空間和數(shù)據(jù)段,所以每當(dāng)啟動(dòng)一個(gè)新的進(jìn)程必須分配給它獨(dú)立的地址空間若专,建立眾多的數(shù)據(jù)表來(lái)維護(hù)它的代碼段许蓖、堆棧段和數(shù)據(jù)段蝴猪,這對(duì)于多進(jìn)程來(lái)說(shuō)十分“奢侈”调衰,系統(tǒng)開(kāi)銷比較大,而線程不一樣自阱,線程擁有獨(dú)立的堆椇坷颍空間,但是共享數(shù)據(jù)段沛豌,它們彼此之間使用相同的地址空間趋箩,共享大部分?jǐn)?shù)據(jù),比進(jìn)程更節(jié)儉加派,開(kāi)銷比較小叫确,切換速度也比進(jìn)程快,效率高芍锦,但是正由于進(jìn)程之間獨(dú)立的特點(diǎn)竹勉,使得進(jìn)程安全性比較高,也因?yàn)檫M(jìn)程有獨(dú)立的地址空間娄琉,一個(gè)進(jìn)程崩潰后次乓,在保護(hù)模式下不會(huì)對(duì)其它進(jìn)程產(chǎn)生影響吓歇,而線程只是一個(gè)進(jìn)程中的不同執(zhí)行路徑。一個(gè)線程死掉就等于整個(gè)進(jìn)程死掉票腰。
第二:體現(xiàn)在通信機(jī)制上面城看,正因?yàn)檫M(jìn)程之間互不干擾,相互獨(dú)立杏慰,進(jìn)程的通信機(jī)制相對(duì)很復(fù)雜测柠,譬如管道,信號(hào)缘滥,消息隊(duì)列鹃愤,共享內(nèi)存,套接字等通信機(jī)制完域,而線程由于共享數(shù)據(jù)段所以通信機(jī)制很方便软吐。。
3.屬于同一個(gè)進(jìn)程的所有線程共享該進(jìn)程的所有資源吟税,包括文件描述符凹耙。而不同過(guò)的進(jìn)程相互獨(dú)立。
4.線程又稱為輕量級(jí)進(jìn)程肠仪,進(jìn)程有進(jìn)程控制塊肖抱,線程有線程控制塊;
5.線程必定也只能屬于一個(gè)進(jìn)程异旧,而進(jìn)程可以擁有多個(gè)線程而且至少擁有一個(gè)線程意述;
第四:體現(xiàn)在程序結(jié)構(gòu)上,舉一個(gè)簡(jiǎn)明易懂的列子:當(dāng)我們使用進(jìn)程的時(shí)候吮蛹,我們不自主的使用if else嵌套來(lái)判斷pid荤崇,使得程序結(jié)構(gòu)繁瑣,但是當(dāng)我們使用線程的時(shí)候潮针,基本上可以甩掉它术荤,當(dāng)然程序內(nèi)部執(zhí)行功能單元需要使用的時(shí)候還是要使用,所以線程對(duì)程序結(jié)構(gòu)的改善有很大幫助每篷。
線程和進(jìn)程各自有什么區(qū)別和優(yōu)劣呢瓣戚?
進(jìn)程是資源分配的最小單位,線程是程序執(zhí)行的最小單位焦读。
進(jìn)程有自己的獨(dú)立地址空間子库,每啟動(dòng)一個(gè)進(jìn)程,系統(tǒng)就會(huì)為它分配地址空間矗晃,建立數(shù)據(jù)表來(lái)維護(hù)代碼段仑嗅、堆棧段和數(shù)據(jù)段,這種操作非常昂貴。而線程是共享進(jìn)程中的數(shù)據(jù)的无畔,使用相同的地址空間啊楚,因此CPU切換一個(gè)線程的花費(fèi)遠(yuǎn)比進(jìn)程要小很多,同時(shí)創(chuàng)建一個(gè)線程的開(kāi)銷也比進(jìn)程要小很多浑彰。
線程之間的通信更方便恭理,同一進(jìn)程下的線程共享全局變量、靜態(tài)變量等數(shù)據(jù)郭变,而進(jìn)程之間的通信需要以通信的方式(IPC)進(jìn)行颜价。不過(guò)如何處理好同步與互斥是編寫(xiě)多線程程序的難點(diǎn)。
但是多進(jìn)程程序更健壯诉濒,多線程程序只要有一個(gè)線程死掉周伦,整個(gè)進(jìn)程也死掉了,而一個(gè)進(jìn)程死掉并不會(huì)對(duì)另外一個(gè)進(jìn)程造成影響未荒,因?yàn)檫M(jìn)程有自己獨(dú)立的地址空間专挪。
進(jìn)程與線程的選擇取決以下幾點(diǎn):
1、需要頻繁創(chuàng)建銷毀的優(yōu)先使用線程片排;因?yàn)閷?duì)進(jìn)程來(lái)說(shuō)創(chuàng)建和銷毀一個(gè)進(jìn)程代價(jià)是很大的寨腔。
2、線程的切換速度快率寡,所以在需要大量計(jì)算迫卢,切換頻繁時(shí)用線程,還有耗時(shí)的操作使用線程可提高應(yīng)用程序的響應(yīng)
3冶共、因?yàn)閷?duì)CPU系統(tǒng)的效率使用上線程更占優(yōu)乾蛤,所以可能要發(fā)展到多機(jī)分布的用進(jìn)程,多核分布用線程捅僵;
4家卖、并行操作時(shí)使用線程,如C/S架構(gòu)的服務(wù)器端并發(fā)線程響應(yīng)用戶的請(qǐng)求命咐;
5篡九、需要更穩(wěn)定安全時(shí),適合選擇進(jìn)程醋奠;需要速度時(shí),選擇線程更好