當(dāng)前位置:首頁 > 公眾號精選 > wenzi嵌入式軟件
[導(dǎo)讀]進(jìn)程的概念進(jìn)程是Linux事務(wù)管理的基本單元,所有的進(jìn)程均擁有自己獨立的處理環(huán)境和系統(tǒng)資源。進(jìn)程的環(huán)境由當(dāng)前系統(tǒng)狀態(tài)及其父進(jìn)程信息決定和組成,將某個可執(zhí)行文件加載到內(nèi)存中運行,那么就會演變成一個或者是多個進(jìn)程。(產(chǎn)生多個進(jìn)程的原因是進(jìn)程在運行的時候可以再創(chuàng)建新的進(jìn)程,但是加載的時...

進(jìn)程的概念

進(jìn)程是 Linux 事務(wù)管理的基本單元,所有的進(jìn)程均擁有自己獨立的處理環(huán)境和系統(tǒng)資源。進(jìn)程的環(huán)境由當(dāng)前系統(tǒng)狀態(tài)及其父進(jìn)程信息決定和組成,將某個可執(zhí)行文件加載到內(nèi)存中運行,那么就會演變成一個或者是多個進(jìn)程。(產(chǎn)生多個進(jìn)程的原因是進(jìn)程在運行的時候可以再創(chuàng)建新的進(jìn)程,但是加載的時候只有一個進(jìn)程),為了更好的理解進(jìn)程,以我們平時在 Linux 環(huán)境下運行一個 C 程序為例進(jìn)行說明:
代碼很簡單,hello world:

#include?

int?main(void)
{
????printf("hello?world!!!!\r\n");
????while(1);
}
如下是在終端執(zhí)行的命令:

image-20210619160036037

進(jìn)程和可執(zhí)行文件的區(qū)別

說到這里,有必要說一下程序和進(jìn)程之間的關(guān)系,程序是存放在存儲介質(zhì)上的一個可執(zhí)行文件,而進(jìn)程是程序執(zhí)行的過程。進(jìn)程的狀態(tài)是變化的,其中包括進(jìn)程的創(chuàng)建、調(diào)度和消亡,程序是靜態(tài)的,而對于進(jìn)程來說是動態(tài)的。

我們在終端運行如下命令,可以看到如下的信息:

image-20210619161052672
從上述可以看出,可執(zhí)行文件在存儲時,可以分為:代碼區(qū)(text)、數(shù)據(jù)區(qū)(data)和未初始化數(shù)據(jù)區(qū)(bss)三部分。對于一個進(jìn)程來說,一個進(jìn)程是一個運行著的程序段,一個進(jìn)程主要包括在內(nèi)存中宏申請的空間,代碼(加載的程序,包括代碼段,數(shù)據(jù)段,BSS)、堆、棧以及內(nèi)核進(jìn)程信息結(jié)構(gòu),打開的文件、上下文信息以及掛起的信號等。下面列出了可執(zhí)行文件和進(jìn)程的結(jié)構(gòu):

image-20210619162214886

進(jìn)程的資源

為了更好地管理 Linux 所訪問地資源,系統(tǒng)在內(nèi)核頭文件?include/linux/sched.h中定義了結(jié)構(gòu)體?struct task_struct來管理每個進(jìn)程地資源,下圖中結(jié)構(gòu)體中一部分成員的代碼截圖:

image-20210619164701518
圖中僅僅知識呈現(xiàn)出一小部分內(nèi)容,結(jié)構(gòu)體 struct task_struct 主要包括線程基本信息、內(nèi)存信息、tty 終端信息,當(dāng)前目錄信息、打開的文件描述符以及信號信息,除了這些,還有其他進(jìn)程屬性,例如:PID、PPID、UID、EUID。下圖是一個關(guān)于結(jié)構(gòu)體的一個示意圖:

image-20210619165014962

進(jìn)程的狀態(tài)

對于單 CPU 系統(tǒng)來說,在某一個時刻,只能有一個進(jìn)程處于運行狀態(tài),其他進(jìn)程都處于其他狀態(tài),等待系統(tǒng)資源,各個任務(wù)根據(jù)調(diào)度算法在這些狀態(tài)之間不停地切換。在Linux 2.6.12內(nèi)核中,用戶級進(jìn)程主要有以下幾種狀態(tài):就緒/運行狀態(tài)、可中斷地等待狀態(tài),不可中斷地等待狀態(tài),停止?fàn)顟B(tài)和僵死狀態(tài)。下面是代碼各個狀態(tài)的宏定義:

#define??TASK_RUNNING??????????0????/*?就緒?*/
#define??TASK_INTERRUPTIBLE????1????/*?中斷等待?*/
#define??TASK_UNINTERRUPTIBLE??2????/*?不可中斷等待?*/
#define??TASK_ZOMBIE???????????4????/*?僵死?*/
#define??TASK_STOPPED??????????8????/*?停止?*/
下面示意圖是用戶級進(jìn)程各個狀態(tài)之間地切換示意圖:

image-20210619171952351
而對于內(nèi)核進(jìn)程狀態(tài)來說略有差異,其狀態(tài)定義如下:

image-20210619173748862

進(jìn)程的屬性

pid tgid 的概念

在講述這兩個概念之前,先引入 Linux 中的另外一個概念,也就是線程,在前面提到,進(jìn)程是資源分配的基本單元,那對于線程來講,線程是 CPU 調(diào)度的最小單位。一個程序中至少有一個進(jìn)程,一個進(jìn)程中至少有一個線程。

其實,在?Linux里,無論是進(jìn)程,還是線程,到了內(nèi)核里面,都統(tǒng)一叫做任務(wù)(Task),并且由一個統(tǒng)一的結(jié)構(gòu)task_struct進(jìn)行管理。下圖是任務(wù)管理的一個示意圖:

image-20210619205649845
如上圖所示的任務(wù)列表一樣,所有執(zhí)行的項目有個項目列表,所以也應(yīng)該有一個鏈表,將所有的?task_struct串起來,比如應(yīng)該有如下所示的數(shù)據(jù)結(jié)構(gòu):

struct?list_head?????tasks;
對于每一個任務(wù)來說,都應(yīng)該有一個ID,作為這個任務(wù)的唯一標(biāo)識。在task_struct里面涉及到任務(wù)ID的,有下面幾個:

pid_t?pid;
pid_t?tpid;
struct?task_struct?*group_leader;
上述中,pidprocess id,tgidthread group ID,對于任何一個進(jìn)程,如果只有主線程,那么pid是自己,tgid也是自己,group_leader指向的還是自己。

但是,如果一個進(jìn)程創(chuàng)建了其他進(jìn)程,那么就會有所變化了。線程有自己的pid,tgid就是進(jìn)程的主線程pid,group leader?指向的就是進(jìn)程的主線程。

父進(jìn)程號(PPID)

任何進(jìn)程(除 init 進(jìn)程)都是由另一個進(jìn)程創(chuàng)建,該進(jìn)程稱為被創(chuàng)建進(jìn)程的父進(jìn)程,被創(chuàng)建的進(jìn)程稱為子進(jìn)程,父進(jìn)程號無法在用戶層修改。父進(jìn)程的進(jìn)程號(PID)即為子進(jìn)程的父進(jìn)程號(PPID)。

進(jìn)程組號(PGID)

在?Linux系統(tǒng)中,進(jìn)程擁有自己的進(jìn)程號(PID)和進(jìn)程組號(PGID),進(jìn)程組是一個或者多個進(jìn)程的集合,它們與同一作業(yè)相關(guān)聯(lián),可以接收來自同一終端的各種信號。每個進(jìn)程組都有唯一的進(jìn)程組號,進(jìn)程組號可以在用戶層進(jìn)行修改。

為了更好的說明上述幾個“號”之間的區(qū)別,給出如下所示的代碼:

#include?
#include?

int?main(int?argc,?char?**argv)
{
????int?i;
????printf("\t?pid\t?ppid?\t?pgid\n");
????printf("parent\t%d\t%d\t%d\n",getpid(),?getppid(),?getpgid(0));

????for?(i?=?0;?i?2;?i )?
????????if?(fork()?==?0)
????????????printf("child\t%d\t%d\t%d\n",getpid(),?getppid(),?getpgid(0));
????return?0;
}
運行代碼,得到的結(jié)果如下所示:

image-20210619220301951
可以看到,第一行,主進(jìn)程,pid = pgid,也就是說父進(jìn)程也就是當(dāng)前的shell,第二行,子進(jìn)程,pid 依次增加,pgid=ppid,符合上述的說法

會話

會話,是一個或多個進(jìn)程組的集合,系統(tǒng)調(diào)用函數(shù)getsid()用來獲取某個進(jìn)程的會話ID(SID)。

比如說,我們通過SSH登陸服務(wù)器,就會打開一個控制終端(TTY),這個控制終端就對應(yīng)一個會話。而我們在終端中運行的命令以及他們的子進(jìn)程,就構(gòu)成了一個個進(jìn)程組,其中,在后臺運行的命令,構(gòu)成的是后臺進(jìn)程組;在前臺運行的命令,構(gòu)成前臺進(jìn)程組。

image-20210619223140086

小結(jié)

上述就是本次關(guān)于 Linux 進(jìn)程的一個概述,僅僅是一個概述,沒有從很深的層面去分析,而且關(guān)于 Linux 進(jìn)程的內(nèi)容還有很多,這次只是說了其中一方面,不積硅步,無以至千里,加油呀。

如果您覺得我的文章,對您有所幫助,歡迎關(guān)注我的個人公眾號:wenzi嵌入式軟件


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

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

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

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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