首頁常見問題正文

線程和進(jìn)程有哪些區(qū)別和不同?

更新時(shí)間:2023-04-27 來源:黑馬程序員 瀏覽量:

IT培訓(xùn)班

進(jìn)程——資源分配的最小單位,線程——程序執(zhí)行的最小單位。

線程進(jìn)程的區(qū)別體現(xiàn)在幾個(gè)方面:

第一:因?yàn)檫M(jìn)程擁有獨(dú)立的堆??臻g和數(shù)據(jù)段,所以每當(dāng)啟動(dòng)一個(gè)新的進(jìn)程必須分配給它獨(dú)立的地址空間,建立眾多的數(shù)據(jù)表來維護(hù)它的代碼段、堆棧段和數(shù)據(jù)段,這對(duì)于多進(jìn)程來說十分“奢侈”,系統(tǒng)開銷比較大,而線程不一樣,線程擁有獨(dú)立的堆??臻g,但是共享數(shù)據(jù)段,它們彼此之間使用相同的地址空間,共享大部分?jǐn)?shù)據(jù),比進(jìn)程更節(jié)儉,開銷比較小,切換速度也比進(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)程的所有資源,包括文件描述符。而不同過的進(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嵌套來判斷 pid,使得程序結(jié)構(gòu)繁瑣,但是當(dāng)我們使用線程的時(shí)候,基本上可以甩掉它,當(dāng)然程序內(nèi)部執(zhí)行功能單元需要使用的時(shí)候還是要使用,所以線程對(duì)程序結(jié)構(gòu)的改善有很大幫助。



分享到:
在線咨詢 我要報(bào)名
和我們?cè)诰€交談!