進(jìn)程控制開(kāi)發(fā)之:Linux進(jìn)程控制編程
此程序的運行結果與在shell中直接鍵入命令“ps-ef”是一樣的,當然,在不同系統的不同時(shí)刻都可能會(huì )有不同的結果。
接下來(lái)的示例使用完整的文件目錄來(lái)查找對應的可執行文件。注意目錄必須以“/”開(kāi)頭,否則將其視為文件名。
/*execl.c*/
#includeunistd.h>
#includestdio.h>
#includestdlib.h>
intmain()
{
if(fork()==0)
{
/*調用execl()函數,注意這里要給出ps程序所在的完整路徑*/
if(execl(/bin/ps,ps,-ef,NULL)0)
{
printf(Execlerrorn);
}
}
}
同樣下載到目標板上運行,運行結果同上例。
下面的示例利用函數execle(),將環(huán)境變量添加到新建的子進(jìn)程中,這里的“env”是查看當前進(jìn)程環(huán)境變量的命令,如下所示:
/*execle.c*/
#includeunistd.h>
#includestdio.h>
#includestdlib.h>
intmain()
{
/*命令參數列表,必須以NULL結尾*/
char*envp[]={PATH=/tmp,USER=david,NULL};
if(fork()==0)
{
/*調用execle()函數,注意這里也要指出env的完整路徑*/
if(execle(/usr/bin/env,env,NULL,envp)0)
{
printf(Execleerrorn);
}
}
}
下載到目標板后的運行結果如下所示:
$./execle
PATH=/tmp
USER=sunq
最后一個(gè)示例使用execve()函數,通過(guò)構造指針數組的方式來(lái)傳遞參數,注意參數列表一定要以NULL作為結尾標識符。其代碼和運行結果如下所示:
#includeunistd.h>
#includestdio.h>
#includestdlib.h>
intmain()
{
/*命令參數列表,必須以NULL結尾*/
char*arg[]={env,NULL};
char*envp[]={PATH=/tmp,USER=david,NULL};
if(fork()==0)
{
if(execve(/usr/bin/env,arg,envp)0)
{
printf(Execveerrorn);
}
}
}
下載到目標板后的運行結果如下所示:
$./execve
PATH=/tmp
USER=david
(4)exec函數族使用注意點(diǎn)。
在使用exec函數族時(shí),一定要加上錯誤判斷語(yǔ)句。exec很容易執行失敗,其中最常見(jiàn)的原因有:
n 找不到文件或路徑,此時(shí)errno被設置為ENOENT;
n 數組argv和envp忘記用NULL結束,此時(shí)errno被設置為EFAULT;
n 沒(méi)有對應可執行文件的運行權限,此時(shí)errno被設置為EACCES。
小知識 | 事實(shí)上,這6個(gè)函數中真正的系統調用只有execve(),其他5個(gè)都是庫函數,它們最終都會(huì )調用execve()這個(gè)系統調用。 |
評論