資料介紹
7.2 Linux進程控制編程
1.fork()
在Linux中創(chuàng)建一個新進程的惟一方法是使用fork()函數(shù)。fork()函數(shù)是Linux中一個非常重要的函數(shù),和讀者以往遇到的函數(shù)有一些區(qū)別,因為它看起來執(zhí)行一次卻返回兩個值。難道一個函數(shù)真的能返回兩個值嗎?希望讀者能認真地學(xué)習(xí)這一部分的內(nèi)容。
?。?)fork()函數(shù)說明。
fork()函數(shù)用于從已存在的進程中創(chuàng)建一個新進程。新進程稱為子進程,而原進程稱為父進程。使用fork()函數(shù)得到的子進程是父進程的一個復(fù)制品,它從父進程處繼承了整個進程的地址空間,包括進程上下文、代碼段、進程堆棧、內(nèi)存信息、打開的文件描述符、信號控制設(shè)定、進程優(yōu)先級、進程組號、當前工作目錄、根目錄、資源限制和控制終端等,而子進程所獨有的只有它的進程號、資源使用和計時器等。
因為子進程幾乎是父進程的完全復(fù)制,所以父子兩個進程會運行同一個程序。因此需要用一種方式來區(qū)分它們,并使它們照此運行,否則,這兩個進程不可能做不同的事。
實際上是在父進程中執(zhí)行fork()函數(shù)時,父進程會復(fù)制出一個子進程,而且父子進程的代碼從fork()函數(shù)的返回開始分別在兩個地址空間中同時運行。從而兩個進程分別獲得其所屬fork()的返回值,其中在父進程中的返回值是子進程的進程號,而在子進程中返回0。因此,可以通過返回值來判定該進程是父進程還是子進程。
同時可以看出,使用fork()函數(shù)的代價是很大的,它復(fù)制了父進程中的代碼段、數(shù)據(jù)段和堆棧段里的大部分內(nèi)容,使得fork()函數(shù)的系統(tǒng)開銷比較大,而且執(zhí)行速度也不是很快。
(2)fork()函數(shù)語法。
表7.2列出了fork()函數(shù)的語法要點。
表7.2 fork()函數(shù)語法要點
所需頭文件#include 《sys/types.h》 // 提供類型pid_t的定義
#include 《unistd.h》
函數(shù)原型pid_t fork(void)
函數(shù)返回值0:子進程
子進程ID(大于0的整數(shù)):父進程
-1:出錯
(3)fork()函數(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ù)的返回情況,首先進行出錯處理*/
if(result == -1)
{
printf(“Fork error\n”);
}
else if (result == 0) /*返回值為0代表子進程*/
{
printf(“The returned value is %d\n
In child process?。nMy PID is %d\n”,result,getpid());
}
else /*返回值大于0代表父進程*/
{
printf(“The returned value is %d\n
In father process??!\nMy PID is %d\n”,result,getpid());
}
return result;
}
將可執(zhí)行程序下載到目標板上,運行結(jié)果如下所示:
$ arm-linux-gcc fork.c –o fork (或者修改Makefile)
$ 。/fork
The returned value is 76 /* 在父進程中打印的信息 */
In father process??!
My PID is 75
The returned value is :0 /* 在子進程中打印的信息 */
In child process??!
My PID is 76
從該實例中可以看出,使用fork()函數(shù)新建了一個子進程,其中的父進程返回子進程的PID,而子進程的返回值為0。
(4)函數(shù)使用注意點。
fork()函數(shù)使用一次就創(chuàng)建一個進程,所以若把fork()函數(shù)放在了if else判斷語句中則要小心,不能多次使用fork()函數(shù)。
小知識由于fork()完整地復(fù)制了父進程的整個地址空間,因此執(zhí)行速度是比較慢的。為了加快fork()的執(zhí)行速度,有些UNIX系統(tǒng)設(shè)計者創(chuàng)建了vfork()。vfork()也能創(chuàng)建新進程,但它不產(chǎn)生父進程的副本。它是通過允許父子進程可訪問相同物理內(nèi)存從而偽裝了對進程地址空間的真實拷貝,當子進程需要改變內(nèi)存中數(shù)據(jù)時才復(fù)制父進程。這就是著名的“寫操作時復(fù)制”(copy-on-write)技術(shù)。
現(xiàn)在很多嵌入式Linux系統(tǒng)的fork()函數(shù)調(diào)用都采用vfork()函數(shù)的實現(xiàn)方式,實際上uClinux所有的多進程管理都通過vfork()來實現(xiàn)。
2.exec函數(shù)族
?。?)exec函數(shù)族說明。
fork()函數(shù)是用于創(chuàng)建一個子進程,該子進程幾乎復(fù)制了父進程的全部內(nèi)容,但是,這個新創(chuàng)建的進程如何執(zhí)行呢?這個exec函數(shù)族就提供了一個在進程中啟動另一個程序執(zhí)行的方法。它可以根據(jù)指定的文件名或目錄名找到可執(zhí)行文件,并用它來取代原調(diào)用進程的數(shù)據(jù)段、代碼段和堆棧段,在執(zhí)行完之后,原調(diào)用進程的內(nèi)容除了進程號外,其他全部被新的進程替換了。另外,這里的可執(zhí)行文件既可以是二進制文件,也可以是Linux下任何可執(zhí)行的腳本文件。
在Linux中使用exec函數(shù)族主要有兩種情況。
n 當進程認為自己不能再為系統(tǒng)和用戶做出任何貢獻時,就可以調(diào)用exec函數(shù)族中的任意一個函數(shù)讓自己重生。
n 如果一個進程想執(zhí)行另一個程序,那么它就可以調(diào)用fork()函數(shù)新建一個進程,然后調(diào)用exec函數(shù)族中的任意一個函數(shù),這樣看起來就像通過執(zhí)行應(yīng)用程序而產(chǎn)生了一個新進程(這種情況非常普遍)。
1.fork()
在Linux中創(chuàng)建一個新進程的惟一方法是使用fork()函數(shù)。fork()函數(shù)是Linux中一個非常重要的函數(shù),和讀者以往遇到的函數(shù)有一些區(qū)別,因為它看起來執(zhí)行一次卻返回兩個值。難道一個函數(shù)真的能返回兩個值嗎?希望讀者能認真地學(xué)習(xí)這一部分的內(nèi)容。
?。?)fork()函數(shù)說明。
fork()函數(shù)用于從已存在的進程中創(chuàng)建一個新進程。新進程稱為子進程,而原進程稱為父進程。使用fork()函數(shù)得到的子進程是父進程的一個復(fù)制品,它從父進程處繼承了整個進程的地址空間,包括進程上下文、代碼段、進程堆棧、內(nèi)存信息、打開的文件描述符、信號控制設(shè)定、進程優(yōu)先級、進程組號、當前工作目錄、根目錄、資源限制和控制終端等,而子進程所獨有的只有它的進程號、資源使用和計時器等。
因為子進程幾乎是父進程的完全復(fù)制,所以父子兩個進程會運行同一個程序。因此需要用一種方式來區(qū)分它們,并使它們照此運行,否則,這兩個進程不可能做不同的事。
實際上是在父進程中執(zhí)行fork()函數(shù)時,父進程會復(fù)制出一個子進程,而且父子進程的代碼從fork()函數(shù)的返回開始分別在兩個地址空間中同時運行。從而兩個進程分別獲得其所屬fork()的返回值,其中在父進程中的返回值是子進程的進程號,而在子進程中返回0。因此,可以通過返回值來判定該進程是父進程還是子進程。
同時可以看出,使用fork()函數(shù)的代價是很大的,它復(fù)制了父進程中的代碼段、數(shù)據(jù)段和堆棧段里的大部分內(nèi)容,使得fork()函數(shù)的系統(tǒng)開銷比較大,而且執(zhí)行速度也不是很快。
(2)fork()函數(shù)語法。
表7.2列出了fork()函數(shù)的語法要點。
表7.2 fork()函數(shù)語法要點
所需頭文件#include 《sys/types.h》 // 提供類型pid_t的定義
#include 《unistd.h》
函數(shù)原型pid_t fork(void)
函數(shù)返回值0:子進程
子進程ID(大于0的整數(shù)):父進程
-1:出錯
(3)fork()函數(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ù)的返回情況,首先進行出錯處理*/
if(result == -1)
{
printf(“Fork error\n”);
}
else if (result == 0) /*返回值為0代表子進程*/
{
printf(“The returned value is %d\n
In child process?。nMy PID is %d\n”,result,getpid());
}
else /*返回值大于0代表父進程*/
{
printf(“The returned value is %d\n
In father process??!\nMy PID is %d\n”,result,getpid());
}
return result;
}
將可執(zhí)行程序下載到目標板上,運行結(jié)果如下所示:
$ arm-linux-gcc fork.c –o fork (或者修改Makefile)
$ 。/fork
The returned value is 76 /* 在父進程中打印的信息 */
In father process??!
My PID is 75
The returned value is :0 /* 在子進程中打印的信息 */
In child process??!
My PID is 76
從該實例中可以看出,使用fork()函數(shù)新建了一個子進程,其中的父進程返回子進程的PID,而子進程的返回值為0。
(4)函數(shù)使用注意點。
fork()函數(shù)使用一次就創(chuàng)建一個進程,所以若把fork()函數(shù)放在了if else判斷語句中則要小心,不能多次使用fork()函數(shù)。
小知識由于fork()完整地復(fù)制了父進程的整個地址空間,因此執(zhí)行速度是比較慢的。為了加快fork()的執(zhí)行速度,有些UNIX系統(tǒng)設(shè)計者創(chuàng)建了vfork()。vfork()也能創(chuàng)建新進程,但它不產(chǎn)生父進程的副本。它是通過允許父子進程可訪問相同物理內(nèi)存從而偽裝了對進程地址空間的真實拷貝,當子進程需要改變內(nèi)存中數(shù)據(jù)時才復(fù)制父進程。這就是著名的“寫操作時復(fù)制”(copy-on-write)技術(shù)。
現(xiàn)在很多嵌入式Linux系統(tǒng)的fork()函數(shù)調(diào)用都采用vfork()函數(shù)的實現(xiàn)方式,實際上uClinux所有的多進程管理都通過vfork()來實現(xiàn)。
2.exec函數(shù)族
?。?)exec函數(shù)族說明。
fork()函數(shù)是用于創(chuàng)建一個子進程,該子進程幾乎復(fù)制了父進程的全部內(nèi)容,但是,這個新創(chuàng)建的進程如何執(zhí)行呢?這個exec函數(shù)族就提供了一個在進程中啟動另一個程序執(zhí)行的方法。它可以根據(jù)指定的文件名或目錄名找到可執(zhí)行文件,并用它來取代原調(diào)用進程的數(shù)據(jù)段、代碼段和堆棧段,在執(zhí)行完之后,原調(diào)用進程的內(nèi)容除了進程號外,其他全部被新的進程替換了。另外,這里的可執(zhí)行文件既可以是二進制文件,也可以是Linux下任何可執(zhí)行的腳本文件。
在Linux中使用exec函數(shù)族主要有兩種情況。
n 當進程認為自己不能再為系統(tǒng)和用戶做出任何貢獻時,就可以調(diào)用exec函數(shù)族中的任意一個函數(shù)讓自己重生。
n 如果一個進程想執(zhí)行另一個程序,那么它就可以調(diào)用fork()函數(shù)新建一個進程,然后調(diào)用exec函數(shù)族中的任意一個函數(shù),這樣看起來就像通過執(zhí)行應(yīng)用程序而產(chǎ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次下載
- 進程控制塊,信號集是什么資料下載
- XD和XL系列可編程控制器的規(guī)格參數(shù)和輸入輸出接線及運行維護的說明 4次下載
- Linux守護進程詳解 0次下載
- 可編程控制器原理及應(yīng)用 PPT
- 可編程控制器(PLC) 0次下載
- Linux應(yīng)用編程的基本概念 265次閱讀
- Linux中進程、線程和協(xié)程的基礎(chǔ)概念 933次閱讀
- 如何在Linux使用ps/pstree/top命令查看進程 1871次閱讀
- 可編程控制器的基本應(yīng)用詳細講解 7036次閱讀
- 可編程控制器的特點有哪些 8788次閱讀
- 使用AT89C51實現(xiàn)的微型可編程控制器的講解 2861次閱讀
- Linux:測試進程占用的虛擬內(nèi)存大小 2904次閱讀
- 使用可編程控制器需要注意什么事項 4707次閱讀
- 如何使用可編程控制器替代繼電器 5127次閱讀
- Linux進程調(diào)度時機概念分析 2812次閱讀
- 可編程控制器的基本指令_可編程控制器的組成 4987次閱讀
- 可編程控制器與單片機的區(qū)別 1.2w次閱讀
- Linux進程管理:什么是進程?進程的生命周期 8034次閱讀
- 可編程控制器基本知識_可編程控制器原理及應(yīng)用 5.9w次閱讀
- 基于Linux進程管理的詳細剖析 3756次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關(guān)電源基礎(chǔ)知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發(fā)板設(shè)計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關(guān)電源設(shè)計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設(shè)計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論