當(dāng)前位置:首頁(yè) > 公眾號(hào)精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]計(jì)算機(jī)的核心是CPU,它承擔(dān)了計(jì)算機(jī)的所有計(jì)算任務(wù),CPU就像一個(gè)工廠(chǎng),時(shí)刻在運(yùn)行著,而操作系統(tǒng)管理著計(jì)算機(jī),負(fù)責(zé)任務(wù)的調(diào)度、資源的分配和管理。 圖片來(lái)源于網(wǎng)絡(luò) 進(jìn)程和線(xiàn)程都是計(jì)算機(jī)操作系統(tǒng)中的基本概念,在進(jìn)程和線(xiàn)程之上有程序,應(yīng)用程序是具有某種功

計(jì)算機(jī)的核心是CPU,它承擔(dān)了計(jì)算機(jī)的所有計(jì)算任務(wù),CPU就像一個(gè)工廠(chǎng),時(shí)刻在運(yùn)行著,而操作系統(tǒng)管理著計(jì)算機(jī),負(fù)責(zé)任務(wù)的調(diào)度、資源的分配和管理。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

進(jìn)程線(xiàn)程都是計(jì)算機(jī)操作系統(tǒng)中的基本概念,在進(jìn)程和線(xiàn)程之上有程序,應(yīng)用程序是具有某種功能的程序,運(yùn)行在操作系統(tǒng)中。

例如,我們的桌面上都會(huì)安裝QQ、酷狗音樂(lè)、微信......等,這些就是程序。當(dāng)我們點(diǎn)擊QQ運(yùn)行時(shí),QQ正常運(yùn)行,此時(shí)就會(huì)開(kāi)啟一個(gè)進(jìn)程。

因此,「程序是靜態(tài)的,而進(jìn)程是動(dòng)態(tài)的,程序是作為進(jìn)程的運(yùn)行的載體,進(jìn)程會(huì)隨時(shí)間,會(huì)在某一時(shí)刻消亡?!?/strong>

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

我們運(yùn)行程序開(kāi)啟的進(jìn)程,我們可以在任務(wù)管理器中可以查看,當(dāng)我們?cè)俅吸c(diǎn)擊QQ,登陸另一個(gè)賬號(hào)的時(shí)候又會(huì)開(kāi)啟一個(gè)進(jìn)程。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入

打個(gè)比喻:前面我們把CPU比作一個(gè)工廠(chǎng),那么程序就好像工廠(chǎng)里面的車(chē)間。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

但是,車(chē)間是靜態(tài)的,車(chē)間中有多條流水線(xiàn),進(jìn)程就好比流水線(xiàn),流水線(xiàn)是動(dòng)態(tài)執(zhí)行的,一個(gè)車(chē)間可以同時(shí)運(yùn)行多條流水線(xiàn),也可以只執(zhí)行一條流水線(xiàn)或者一條流水線(xiàn)都不執(zhí)行。

總結(jié)來(lái)說(shuō):「程序可以包含多個(gè)進(jìn)程,多個(gè)進(jìn)程并發(fā)執(zhí)行,相互獨(dú)立,因此,進(jìn)程也是系統(tǒng)進(jìn)行資源分配和調(diào)度基本單位?!?/strong>

當(dāng)然,程序也可以沒(méi)有啟動(dòng)進(jìn)程,就好比車(chē)間中沒(méi)有流水線(xiàn),因?yàn)槌绦蚴庆o態(tài)的,而進(jìn)程的有無(wú)就好比層間的流水線(xiàn)是否存在。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

一條流水線(xiàn)上可以有很多工人,那些工人就好比是線(xiàn)程,一個(gè)員工就代表一個(gè)線(xiàn)程,他們?cè)谝黄鸸餐瑓f(xié)作,完成一條流水線(xiàn)上的任務(wù)。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

所以,「進(jìn)程與線(xiàn)程的關(guān)系是包含關(guān)系,一個(gè)進(jìn)程中至少有一個(gè)線(xiàn)程,或者多個(gè)線(xiàn)程,一個(gè)線(xiàn)程只能歸屬于一個(gè)進(jìn)程中」。就好比一個(gè)車(chē)間中可以有多個(gè)流水線(xiàn),一條流水線(xiàn)上有多個(gè)功能開(kāi)工,在組長(zhǎng)安排下工人只能在一條流水線(xiàn)上工作。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

當(dāng)然,進(jìn)程中的所有線(xiàn)程共享這該進(jìn)程的所有資源,比如:內(nèi)存空間,每個(gè)線(xiàn)程都可以使用這個(gè)內(nèi)存空間。就好比車(chē)間中的空間都是各條流水線(xiàn)共享的。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入

不同的空間若能容納的工人也不一樣,就好比廁所一次只能一個(gè)人進(jìn)廁所,當(dāng)后面來(lái)的人,注意到廁所門(mén)已經(jīng)關(guān)閉,就知道里面有人,就只能等候前一個(gè)人用完,他才能用。

廁所里面的人,為了防止他人再次進(jìn)入廁所,就會(huì)把廁所鎖住,這就是「互斥鎖(Mutual exclusion,縮寫(xiě) Mutex)」,這就意味著在進(jìn)程中的某一些空間一次只能由一條線(xiàn)程使用。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

有些空間就會(huì)比較大,一次可以供多個(gè)人使用,比如:休息室,休息室的座位都是有限的,一次只能供20的座位休息,其余的人就坐不下了。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入

用于標(biāo)識(shí)這個(gè)空間僅給20個(gè)人使用的辦法就是給每個(gè)座位打一個(gè)編號(hào)1-20,每進(jìn)去一個(gè)人就給這個(gè)人發(fā)一個(gè)作為編號(hào),當(dāng)編號(hào)用完了,表示這個(gè)空間已經(jīng)滿(mǎn)了。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

當(dāng)有人出來(lái)了就會(huì)把編號(hào)還給看守的那個(gè)人,便是又有空間可以使用了,這個(gè)做法就是「信號(hào)量」,這樣保證了每個(gè)人都有自己的座位,即保證多線(xiàn)程不會(huì)相互沖突。

「那為什么有進(jìn)程還要多線(xiàn)程呢?」 每個(gè)進(jìn)程都有自己獨(dú)自的代碼和數(shù)據(jù)空間,即為「程序的上下文」,進(jìn)程包含多個(gè)線(xiàn)程,進(jìn)程的切換消耗要大于線(xiàn)程的切換消耗。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

線(xiàn)程可以看作是輕量級(jí)的進(jìn)程,每個(gè)線(xiàn)程也有自己的「運(yùn)行棧」「程序計(jì)數(shù)器(PC)」、以及「線(xiàn)程的本地存儲(chǔ)」,所以對(duì)于進(jìn)程數(shù)比較多的,頻繁的切換進(jìn)程將會(huì)帶來(lái)一大筆的開(kāi)銷(xiāo),反而線(xiàn)程的切換開(kāi)銷(xiāo)小。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

進(jìn)程是一個(gè)「動(dòng)態(tài)」的概念,進(jìn)程包含下面的五種狀態(tài):「初始態(tài),執(zhí)行態(tài),等待狀態(tài),就緒狀態(tài),終止?fàn)顟B(tài)」。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

線(xiàn)程中的狀態(tài)也是包含下面的五種:「新建(NEW)、可運(yùn)行(Runnable)、運(yùn)行(Running)、阻塞(BLOCKED)、死亡(DEAD)」

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

那么進(jìn)程之間是怎么交互的呢?在進(jìn)程之間的通信包括「管道、系統(tǒng)IPC(包括消息隊(duì)列,信號(hào)量,共享存儲(chǔ)), SOCKET?!?/strong>

管道的方式由包括以下三種方式:

  1. 「普通管道」 PIPE:通常會(huì)有限制,可能是半雙工方式,或者是只能在子父進(jìn)程中使用。
  2. 「流管道」 s_pipe:可以使用雙向傳輸。
  3. 「命名管道」 name_pipe:它允許可以在不相關(guān)的進(jìn)程之中使用。

線(xiàn)程之間的通信在JMM模型中是通過(guò)共享內(nèi)存來(lái)實(shí)現(xiàn)的,例如:線(xiàn)程一要和線(xiàn)程二通信,線(xiàn)程一先把自己的變量副本寫(xiě)入主內(nèi)存中,然后線(xiàn)程二再?gòu)闹鲀?nèi)存中讀取該變量,復(fù)制到自己的線(xiàn)程空間中進(jìn)行操作,線(xiàn)程都不能直接操作主內(nèi)存。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入

為了保證多線(xiàn)程之間的數(shù)據(jù)一致性的問(wèn)題,可以使用鎖機(jī)制,實(shí)現(xiàn)線(xiàn)程之間的操作的同步、有序。例如:「synchronized鎖、Lock鎖、Atomic原子類(lèi)」。

單線(xiàn)程時(shí)代,一次只能執(zhí)行一個(gè)任務(wù),后面的任務(wù)只能排隊(duì)等候,實(shí)現(xiàn)的方式都是串行化的,隨著后續(xù)的發(fā)展為了提高效率,實(shí)現(xiàn)了多線(xiàn)程。

單CPU的多線(xiàn)程方式,實(shí)現(xiàn)的是并發(fā)方式,并發(fā)真正意義上的并行,因?yàn)镃PU一次只能執(zhí)行一次任務(wù),但是,CPU的執(zhí)行速度遠(yuǎn)快于線(xiàn)程的執(zhí)行速度,為了充分利用CPU,因此實(shí)現(xiàn)并發(fā)的多線(xiàn)程方式。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

多CPU時(shí)代的來(lái)領(lǐng),實(shí)現(xiàn)真正意義上的并行多線(xiàn)程,同一時(shí)刻可以由多個(gè)線(xiàn)程的執(zhí)行。

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入
圖片來(lái)源于網(wǎng)絡(luò)

最后總結(jié):「操作系統(tǒng)中是以多進(jìn)程的形式執(zhí)行,以多線(xiàn)程的方式執(zhí)行,允許講單個(gè)任務(wù)由多個(gè)部分執(zhí)行,并且在多線(xiàn)程之間能夠提供協(xié)調(diào)機(jī)制,允許進(jìn)程之間、線(xiàn)程之間有共享的部分,又能夠保證進(jìn)程之間、線(xiàn)程之間不會(huì)相互影響」

特別推薦一個(gè)分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒(méi)關(guān)注的小伙伴,可以長(zhǎng)按關(guān)注一下:

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入

長(zhǎng)按訂閱更多精彩▼

寫(xiě)給小白看的線(xiàn)程和進(jìn)程,高手勿入

如有收獲,點(diǎn)個(gè)在看,誠(chéng)摯感謝

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀(guān)點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀(guān)點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車(chē)技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車(chē)工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車(chē)。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶(hù)希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱(chēng),數(shù)字世界的話(huà)語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱(chēng)"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉