?進(jìn)程與線程等抽象概念類比:
? *? 計(jì)算器系統(tǒng)對(duì)計(jì)算資源的分配(CPU)和對(duì)內(nèi)存的分配是分開(kāi)進(jìn)行的赶盔。
??*?CPU:計(jì)算機(jī)的核心勒魔,他承擔(dān)了所有的計(jì)算任務(wù)融痛。假設(shè)其為?一座工廠(因?yàn)楝F(xiàn)代的操作系統(tǒng)大都可以執(zhí)行多任務(wù)藤韵。即多核CPU)凛膏,時(shí)刻在生產(chǎn)杨名。
?1.?單核CPU: 一臺(tái)單核處理器計(jì)算機(jī)=-個(gè)車間;
?2.?多核CPU: 一臺(tái)多核處理器計(jì)算機(jī)=一座工廠;
? *? 1個(gè)cpu里面有幾核??一般cpu?4核8g,?8核16g.
??????*?cpu單核和多核的區(qū)別為:?jiǎn)卧M數(shù)不同猖毫、運(yùn)行線程數(shù)不同台谍、執(zhí)行速度不同。
????????一吁断、單元組數(shù)不同
??????????1趁蕊、cpu單核:cpu單核只有1個(gè)獨(dú)立的CPU核心單元組坞生。
??????????2、cpu多核:cpu多核包括2個(gè)相對(duì)獨(dú)立的CPU核心單元組掷伙。
????????二是己、運(yùn)行線程數(shù)不同
??????????1、cpu單核:cpu單核能同時(shí)運(yùn)行的線程數(shù)較多核更少任柜,不利于同時(shí)運(yùn)行多個(gè)程序卒废。死機(jī)卡頓。
??????????2宙地、cpu多核:cpu多核能同時(shí)運(yùn)行的線程數(shù)較單核更多摔认,有利于同時(shí)運(yùn)行多個(gè)程序。
??3.?進(jìn)程: 一個(gè)車間? =? 一個(gè)進(jìn)程;?(即-程序的一次執(zhí)行)
??4.?多進(jìn)程: 一座工廠可以同時(shí)運(yùn)行多個(gè)車間;?
??5.?CPU和進(jìn)程:?單核CPU只能同時(shí)運(yùn)行單個(gè)進(jìn)程绸栅,多核CPU可以同時(shí)運(yùn)行多個(gè)進(jìn)程级野。
??6.?線程: 車間內(nèi)一個(gè)工人? =? 一個(gè)線程;?
??7.?進(jìn)程與線程:? 一個(gè)進(jìn)程可以包括多個(gè)線程。
??8.?線程間內(nèi)存共享:?車間的空間是工人們共享的粹胯。
進(jìn)程(車間)的內(nèi)存空間是天然獨(dú)立的蓖柔,但是線程(工人)的內(nèi)存空間是天然共享的,一個(gè)進(jìn)程有多個(gè)線程风纠】雒看圖
??ps:? 圖為https://baijiahao.baidu.com/s?id=1611925141861592999&wfr=spider&for=pc? 而且該文有提到:?線程沒(méi)有地址空間,線程包含在進(jìn)程的地址空間中竹观。進(jìn)程擁有的所有資源都屬于線程镐捧,所有的線程共享進(jìn)程的內(nèi)存和資源。同一進(jìn)程中的多個(gè)線程共享代碼段(代碼和常量)臭增,數(shù)據(jù)段(全局變量和靜態(tài)變量)懂酱,擴(kuò)展段(堆存儲(chǔ))。但是每個(gè)線程擁有自己的棧段誊抛,?寄存器的內(nèi)容列牺,棧段又叫運(yùn)行時(shí)段,用來(lái)存放所有局部變量和臨時(shí)變量拗窃。
??所以我是這樣理解的,對(duì)上面提及的 【進(jìn)程的內(nèi)存空間是天然獨(dú)立的】 是針對(duì)多進(jìn)程的時(shí)候瞎领,不同進(jìn)程與進(jìn)程之間是相對(duì)獨(dú)立,無(wú)法訪問(wèn)的随夸,即A車間與B車間之間是相互獨(dú)立的九默。這樣的話A車間的所有內(nèi)存和資源,A車間的工人都可以共享宾毒。也就是下面這些:
????-?進(jìn)程的內(nèi)存空間是共享的驼修,每個(gè)線程都可以使用這些共享內(nèi)存。
????-?內(nèi)存安全: 由于該車間的每個(gè)房間容納大小不同,有的最多只能容納一個(gè)人(一個(gè)線程)邪锌∶闾桑空間人滿的時(shí)候,其他人就進(jìn)不去了觅丰。
????-?個(gè)線程使用某些共享內(nèi)存時(shí),其他線程必須等它結(jié)束妨退,才能使用這-塊內(nèi)存妇萄,這種線程間同步是為了防止競(jìng)爭(zhēng)(就是說(shuō)因同時(shí)修改,而導(dǎo)致的數(shù)據(jù)不一致)咬荷。
????-?互斥鎖: 防止兩個(gè)線程同時(shí)讀寫某塊內(nèi)存區(qū)域(假如兩個(gè)線程同時(shí)做修改冠句,會(huì)導(dǎo)致數(shù)據(jù)不一致),所以可以理解為我在使用某個(gè)獨(dú)間幸乒,你想要使用你必須等我用完懦底,所以讓你知道我在用的最好的辦法就是你進(jìn)不來(lái),也就是上鎖罕扎,如果我使用完了我就會(huì)解鎖聚唐,然后你就可以用了。
????-?信號(hào)量: 這時(shí)的解決方法腔召,就是在門口掛n把鑰匙牌杆查。進(jìn)去的人就取-把鑰匙牌,出來(lái)時(shí)再把鑰匙牌掛回原處臀蛛。后到的人發(fā)現(xiàn)鑰匙牌架空了亲桦,就知?道必須在門口排隊(duì)等著了。
????這種做法叫做"信號(hào)量”(Semaphore)?浊仆,用來(lái)告訴你你可以使用還是需要等待客峭,以保證多個(gè)線程不會(huì)互相沖突。
????-?鎖和信號(hào)量:不難看出抡柿,互斥鎖是信號(hào)量的一種特殊情況(n=1時(shí))?舔琅。也就是說(shuō),完全可以用后者替代前者沙绝。但是搏明,因?yàn)?mutex(互斥鎖) 較為簡(jiǎn)單,且效率高闪檬,所以在必須保證資源獨(dú)占的情況下星著,還是采用這種設(shè)計(jì)。
? ryf總結(jié): 不難看出粗悯,mutex是semaphore的一種特殊情況(n=1時(shí))虚循。也就是說(shuō),完全可以用后者替代前者(n)。但是横缔,因?yàn)閙utex較為簡(jiǎn)單铺遂,且效率高,所以在必須保證【資源獨(dú)占】的情況下茎刚,還是采用這種設(shè)計(jì)襟锐。