資料介紹
7.2 Linux進(jìn)程控制編程
1.fork()
在Linux中創(chuàng)建一個新進(jìn)程的惟一方法是使用fork()函數(shù)。fork()函數(shù)是Linux中一個非常重要的函數(shù),和讀者以往遇到的函數(shù)有一些區(qū)別,因?yàn)樗雌饋韴?zhí)行一次卻返回兩個值。難道一個函數(shù)真的能返回兩個值嗎?希望讀者能認(rèn)真地學(xué)習(xí)這一部分的內(nèi)容。
(1)fork()函數(shù)說明。
fork()函數(shù)用于從已存在的進(jìn)程中創(chuàng)建一個新進(jìn)程。新進(jìn)程稱為子進(jìn)程,而原進(jìn)程稱為父進(jìn)程。使用fork()函數(shù)得到的子進(jìn)程是父進(jìn)程的一個復(fù)制品,它從父進(jìn)程處繼承了整個進(jìn)程的地址空間,包括進(jìn)程上下文、代碼段、進(jìn)程堆棧、內(nèi)存信息、打開的文件描述符、信號控制設(shè)定、進(jìn)程優(yōu)先級、進(jìn)程組號、當(dāng)前工作目錄、根目錄、資源限制和控制終端等,而子進(jìn)程所獨(dú)有的只有它的進(jìn)程號、資源使用和計時器等。
因?yàn)樽舆M(jìn)程幾乎是父進(jìn)程的完全復(fù)制,所以父子兩個進(jìn)程會運(yùn)行同一個程序。因此需要用一種方式來區(qū)分它們,并使它們照此運(yùn)行,否則,這兩個進(jìn)程不可能做不同的事。
實(shí)際上是在父進(jìn)程中執(zhí)行fork()函數(shù)時,父進(jìn)程會復(fù)制出一個子進(jìn)程,而且父子進(jìn)程的代碼從fork()函數(shù)的返回開始分別在兩個地址空間中同時運(yùn)行。從而兩個進(jìn)程分別獲得其所屬fork()的返回值,其中在父進(jìn)程中的返回值是子進(jìn)程的進(jìn)程號,而在子進(jìn)程中返回0。因此,可以通過返回值來判定該進(jìn)程是父進(jìn)程還是子進(jìn)程。
同時可以看出,使用fork()函數(shù)的代價是很大的,它復(fù)制了父進(jìn)程中的代碼段、數(shù)據(jù)段和堆棧段里的大部分內(nèi)容,使得fork()函數(shù)的系統(tǒng)開銷比較大,而且執(zhí)行速度也不是很快。
?。?)fork()函數(shù)語法。
表7.2列出了fork()函數(shù)的語法要點(diǎn)。
表7.2 fork()函數(shù)語法要點(diǎn)
所需頭文件#include 《sys/types.h》 // 提供類型pid_t的定義
#include 《unistd.h》
函數(shù)原型pid_t fork(void)
函數(shù)返回值0:子進(jìn)程
子進(jìn)程ID(大于0的整數(shù)):父進(jìn)程
-1:出錯
?。?)fork()函數(shù)使用實(shí)例。
/* fork.c */
#include 《sys/types.h》
#include 《unistd.h》
#include 《stdio.h》
#include 《stdlib.h》
int main(void)
{
pid_t result;
/*調(diào)用fork()函數(shù)*/
result = fork();
/*通過result的值來判斷fork()函數(shù)的返回情況,首先進(jìn)行出錯處理*/
if(result == -1)
{
printf(“Fork error\n”);
}
else if (result == 0) /*返回值為0代表子進(jìn)程*/
{
printf(“The returned value is %d\n
In child process??!\nMy PID is %d\n”,result,getpid());
}
else /*返回值大于0代表父進(jìn)程*/
{
printf(“The returned value is %d\n
In father process?。nMy PID is %d\n”,result,getpid());
}
return result;
}
將可執(zhí)行程序下載到目標(biāo)板上,運(yùn)行結(jié)果如下所示:
$ arm-linux-gcc fork.c –o fork (或者修改Makefile)
$ 。/fork
The returned value is 76 /* 在父進(jìn)程中打印的信息 */
In father process!!
My PID is 75
The returned value is :0 /* 在子進(jìn)程中打印的信息 */
In child process??!
My PID is 76
從該實(shí)例中可以看出,使用fork()函數(shù)新建了一個子進(jìn)程,其中的父進(jìn)程返回子進(jìn)程的PID,而子進(jìn)程的返回值為0。
(4)函數(shù)使用注意點(diǎn)。
fork()函數(shù)使用一次就創(chuàng)建一個進(jìn)程,所以若把fork()函數(shù)放在了if else判斷語句中則要小心,不能多次使用fork()函數(shù)。
小知識由于fork()完整地復(fù)制了父進(jìn)程的整個地址空間,因此執(zhí)行速度是比較慢的。為了加快fork()的執(zhí)行速度,有些UNIX系統(tǒng)設(shè)計者創(chuàng)建了vfork()。vfork()也能創(chuàng)建新進(jìn)程,但它不產(chǎn)生父進(jìn)程的副本。它是通過允許父子進(jìn)程可訪問相同物理內(nèi)存從而偽裝了對進(jìn)程地址空間的真實(shí)拷貝,當(dāng)子進(jìn)程需要改變內(nèi)存中數(shù)據(jù)時才復(fù)制父進(jìn)程。這就是著名的“寫操作時復(fù)制”(copy-on-write)技術(shù)。
現(xiàn)在很多嵌入式Linux系統(tǒng)的fork()函數(shù)調(diào)用都采用vfork()函數(shù)的實(shí)現(xiàn)方式,實(shí)際上uClinux所有的多進(jìn)程管理都通過vfork()來實(shí)現(xiàn)。
2.exec函數(shù)族
?。?)exec函數(shù)族說明。
fork()函數(shù)是用于創(chuàng)建一個子進(jìn)程,該子進(jìn)程幾乎復(fù)制了父進(jìn)程的全部內(nèi)容,但是,這個新創(chuàng)建的進(jìn)程如何執(zhí)行呢?這個exec函數(shù)族就提供了一個在進(jìn)程中啟動另一個程序執(zhí)行的方法。它可以根據(jù)指定的文件名或目錄名找到可執(zhí)行文件,并用它來取代原調(diào)用進(jìn)程的數(shù)據(jù)段、代碼段和堆棧段,在執(zhí)行完之后,原調(diào)用進(jìn)程的內(nèi)容除了進(jìn)程號外,其他全部被新的進(jìn)程替換了。另外,這里的可執(zhí)行文件既可以是二進(jìn)制文件,也可以是Linux下任何可執(zhí)行的腳本文件。
在Linux中使用exec函數(shù)族主要有兩種情況。
n 當(dāng)進(jìn)程認(rèn)為自己不能再為系統(tǒng)和用戶做出任何貢獻(xiàn)時,就可以調(diào)用exec函數(shù)族中的任意一個函數(shù)讓自己重生。
n 如果一個進(jìn)程想執(zhí)行另一個程序,那么它就可以調(diào)用fork()函數(shù)新建一個進(jìn)程,然后調(diào)用exec函數(shù)族中的任意一個函數(shù),這樣看起來就像通過執(zhí)行應(yīng)用程序而產(chǎn)生了一個新進(jìn)程(這種情況非常普遍)。
1.fork()
在Linux中創(chuàng)建一個新進(jìn)程的惟一方法是使用fork()函數(shù)。fork()函數(shù)是Linux中一個非常重要的函數(shù),和讀者以往遇到的函數(shù)有一些區(qū)別,因?yàn)樗雌饋韴?zhí)行一次卻返回兩個值。難道一個函數(shù)真的能返回兩個值嗎?希望讀者能認(rèn)真地學(xué)習(xí)這一部分的內(nèi)容。
(1)fork()函數(shù)說明。
fork()函數(shù)用于從已存在的進(jìn)程中創(chuàng)建一個新進(jìn)程。新進(jìn)程稱為子進(jìn)程,而原進(jìn)程稱為父進(jìn)程。使用fork()函數(shù)得到的子進(jìn)程是父進(jìn)程的一個復(fù)制品,它從父進(jìn)程處繼承了整個進(jìn)程的地址空間,包括進(jìn)程上下文、代碼段、進(jìn)程堆棧、內(nèi)存信息、打開的文件描述符、信號控制設(shè)定、進(jìn)程優(yōu)先級、進(jìn)程組號、當(dāng)前工作目錄、根目錄、資源限制和控制終端等,而子進(jìn)程所獨(dú)有的只有它的進(jìn)程號、資源使用和計時器等。
因?yàn)樽舆M(jìn)程幾乎是父進(jìn)程的完全復(fù)制,所以父子兩個進(jìn)程會運(yùn)行同一個程序。因此需要用一種方式來區(qū)分它們,并使它們照此運(yùn)行,否則,這兩個進(jìn)程不可能做不同的事。
實(shí)際上是在父進(jìn)程中執(zhí)行fork()函數(shù)時,父進(jìn)程會復(fù)制出一個子進(jìn)程,而且父子進(jìn)程的代碼從fork()函數(shù)的返回開始分別在兩個地址空間中同時運(yùn)行。從而兩個進(jìn)程分別獲得其所屬fork()的返回值,其中在父進(jìn)程中的返回值是子進(jìn)程的進(jìn)程號,而在子進(jìn)程中返回0。因此,可以通過返回值來判定該進(jìn)程是父進(jìn)程還是子進(jìn)程。
同時可以看出,使用fork()函數(shù)的代價是很大的,它復(fù)制了父進(jìn)程中的代碼段、數(shù)據(jù)段和堆棧段里的大部分內(nèi)容,使得fork()函數(shù)的系統(tǒng)開銷比較大,而且執(zhí)行速度也不是很快。
?。?)fork()函數(shù)語法。
表7.2列出了fork()函數(shù)的語法要點(diǎn)。
表7.2 fork()函數(shù)語法要點(diǎn)
所需頭文件#include 《sys/types.h》 // 提供類型pid_t的定義
#include 《unistd.h》
函數(shù)原型pid_t fork(void)
函數(shù)返回值0:子進(jìn)程
子進(jìn)程ID(大于0的整數(shù)):父進(jìn)程
-1:出錯
?。?)fork()函數(shù)使用實(shí)例。
/* fork.c */
#include 《sys/types.h》
#include 《unistd.h》
#include 《stdio.h》
#include 《stdlib.h》
int main(void)
{
pid_t result;
/*調(diào)用fork()函數(shù)*/
result = fork();
/*通過result的值來判斷fork()函數(shù)的返回情況,首先進(jìn)行出錯處理*/
if(result == -1)
{
printf(“Fork error\n”);
}
else if (result == 0) /*返回值為0代表子進(jìn)程*/
{
printf(“The returned value is %d\n
In child process??!\nMy PID is %d\n”,result,getpid());
}
else /*返回值大于0代表父進(jìn)程*/
{
printf(“The returned value is %d\n
In father process?。nMy PID is %d\n”,result,getpid());
}
return result;
}
將可執(zhí)行程序下載到目標(biāo)板上,運(yùn)行結(jié)果如下所示:
$ arm-linux-gcc fork.c –o fork (或者修改Makefile)
$ 。/fork
The returned value is 76 /* 在父進(jìn)程中打印的信息 */
In father process!!
My PID is 75
The returned value is :0 /* 在子進(jìn)程中打印的信息 */
In child process??!
My PID is 76
從該實(shí)例中可以看出,使用fork()函數(shù)新建了一個子進(jìn)程,其中的父進(jìn)程返回子進(jìn)程的PID,而子進(jìn)程的返回值為0。
(4)函數(shù)使用注意點(diǎn)。
fork()函數(shù)使用一次就創(chuàng)建一個進(jìn)程,所以若把fork()函數(shù)放在了if else判斷語句中則要小心,不能多次使用fork()函數(shù)。
小知識由于fork()完整地復(fù)制了父進(jìn)程的整個地址空間,因此執(zhí)行速度是比較慢的。為了加快fork()的執(zhí)行速度,有些UNIX系統(tǒng)設(shè)計者創(chuàng)建了vfork()。vfork()也能創(chuàng)建新進(jìn)程,但它不產(chǎn)生父進(jìn)程的副本。它是通過允許父子進(jìn)程可訪問相同物理內(nèi)存從而偽裝了對進(jìn)程地址空間的真實(shí)拷貝,當(dāng)子進(jìn)程需要改變內(nèi)存中數(shù)據(jù)時才復(fù)制父進(jìn)程。這就是著名的“寫操作時復(fù)制”(copy-on-write)技術(shù)。
現(xiàn)在很多嵌入式Linux系統(tǒng)的fork()函數(shù)調(diào)用都采用vfork()函數(shù)的實(shí)現(xiàn)方式,實(shí)際上uClinux所有的多進(jìn)程管理都通過vfork()來實(shí)現(xiàn)。
2.exec函數(shù)族
?。?)exec函數(shù)族說明。
fork()函數(shù)是用于創(chuàng)建一個子進(jìn)程,該子進(jìn)程幾乎復(fù)制了父進(jìn)程的全部內(nèi)容,但是,這個新創(chuàng)建的進(jìn)程如何執(zhí)行呢?這個exec函數(shù)族就提供了一個在進(jìn)程中啟動另一個程序執(zhí)行的方法。它可以根據(jù)指定的文件名或目錄名找到可執(zhí)行文件,并用它來取代原調(diào)用進(jìn)程的數(shù)據(jù)段、代碼段和堆棧段,在執(zhí)行完之后,原調(diào)用進(jìn)程的內(nèi)容除了進(jìn)程號外,其他全部被新的進(jìn)程替換了。另外,這里的可執(zhí)行文件既可以是二進(jìn)制文件,也可以是Linux下任何可執(zhí)行的腳本文件。
在Linux中使用exec函數(shù)族主要有兩種情況。
n 當(dāng)進(jìn)程認(rèn)為自己不能再為系統(tǒng)和用戶做出任何貢獻(xiàn)時,就可以調(diào)用exec函數(shù)族中的任意一個函數(shù)讓自己重生。
n 如果一個進(jìn)程想執(zhí)行另一個程序,那么它就可以調(diào)用fork()函數(shù)新建一個進(jìn)程,然后調(diào)用exec函數(shù)族中的任意一個函數(shù),這樣看起來就像通過執(zhí)行應(yīng)用程序而產(chǎn)生了一個新進(jìn)程(這種情況非常普遍)。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 《圖解繼電器與可編程控制器》岡本裕生著 0次下載
- 可編程控制器AC500用戶手冊 1次下載
- 三菱微型可編程控制器FX1s系列使用手冊 10次下載
- 三菱微型可編程控制器MELSEC-F用戶手冊 0次下載
- AC500可編程控制器用戶手冊 14次下載
- ABB可編程控制器技術(shù)資料 18次下載
- AD714X輸入CapTouch?可編程控制器Linux驅(qū)動程序
- AC500可編程控制器手冊 9次下載
- S7-1200可編程控制器資料手冊 33次下載
- 可編程控制器原理及應(yīng)用 22次下載
- 進(jìn)程控制塊,信號集是什么資料下載
- XD和XL系列可編程控制器的規(guī)格參數(shù)和輸入輸出接線及運(yùn)行維護(hù)的說明 4次下載
- Linux守護(hù)進(jìn)程詳解 0次下載
- 可編程控制器原理及應(yīng)用 PPT
- 可編程控制器(PLC) 0次下載
- Linux應(yīng)用編程的基本概念 265次閱讀
- Linux中進(jìn)程、線程和協(xié)程的基礎(chǔ)概念 933次閱讀
- 如何在Linux使用ps/pstree/top命令查看進(jìn)程 1871次閱讀
- 可編程控制器的基本應(yīng)用詳細(xì)講解 7036次閱讀
- 可編程控制器的特點(diǎn)有哪些 8788次閱讀
- 使用AT89C51實(shí)現(xiàn)的微型可編程控制器的講解 2861次閱讀
- Linux:測試進(jìn)程占用的虛擬內(nèi)存大小 2904次閱讀
- 使用可編程控制器需要注意什么事項(xiàng) 4707次閱讀
- 如何使用可編程控制器替代繼電器 5127次閱讀
- Linux進(jìn)程調(diào)度時機(jī)概念分析 2812次閱讀
- 可編程控制器的基本指令_可編程控制器的組成 4987次閱讀
- 可編程控制器與單片機(jī)的區(qū)別 1.2w次閱讀
- Linux進(jìn)程管理:什么是進(jìn)程?進(jìn)程的生命周期 8034次閱讀
- 可編程控制器基本知識_可編程控制器原理及應(yīng)用 5.9w次閱讀
- 基于Linux進(jìn)程管理的詳細(xì)剖析 3756次閱讀
下載排行
本周
- 1涂鴉各WiFi模塊原理圖加PCB封裝
- 11.75 MB | 76次下載 | 1 積分
- 2錦銳科技CA51F2 SDK開發(fā)包
- 24.06 MB | 29次下載 | 1 積分
- 3錦銳CA51F005 SDK開發(fā)包
- 19.47 MB | 3次下載 | 1 積分
- 4蘋果iphone 11電路原理圖
- 4.98 MB | 3次下載 | 2 積分
- 5基礎(chǔ)模擬電子電路
- 3.80 MB | 3次下載 | 1 積分
- 6RA-Eco-RA6M4-100PIN-V1.0開發(fā)板資料
- 34.89 MB | 1次下載 | 免費(fèi)
- 7STM32F3系列、STM32F4系列、STM32L4系列和STM32L4+系列Cortex-M4編程手冊
- 3.32 MB | 1次下載 | 免費(fèi)
- 8聯(lián)想A820t手機(jī)維修圖紙包括主板原理圖 尾板原理圖 點(diǎn)位圖
- 0.62 MB | 次下載 | 5 積分
本月
- 1AI智能眼鏡產(chǎn)業(yè)鏈分析
- 4.43 MB | 383次下載 | 免費(fèi)
- 2蘇泊爾電磁爐線路的電路原理圖資料合集
- 2.02 MB | 296次下載 | 5 積分
- 3貼片三極管上的印字與真實(shí)名稱的對照表詳細(xì)說明
- 0.50 MB | 94次下載 | 1 積分
- 4長虹液晶電視R-HS310B-5HF01的電源板電路原理圖
- 0.46 MB | 91次下載 | 5 積分
- 5涂鴉各WiFi模塊原理圖加PCB封裝
- 11.75 MB | 76次下載 | 1 積分
- 6錦銳科技CA51F2 SDK開發(fā)包
- 24.06 MB | 29次下載 | 1 積分
- 7AO4803A雙P通道增強(qiáng)型場效應(yīng)晶體管的數(shù)據(jù)手冊
- 0.11 MB | 28次下載 | 2 積分
- 8長虹液晶彩電LS29機(jī)芯的技術(shù)資料說明
- 3.42 MB | 16次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935127次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191388次下載 | 10 積分
- 5十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183342次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81588次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73815次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65988次下載 | 10 積分
評論