C語(yǔ)言system()函數(shù):執(zhí)行shell命令
頭文件:
#include <stdlib.h>
定義函數(shù):
int system(const char * string);
函數(shù)說明:system()會(huì)調(diào)用fork()產(chǎn)生子進(jìn)程, 由子進(jìn)程來調(diào)用/bin/sh-c string 來執(zhí)行參數(shù)string 字符串所代表的命令, 此命令執(zhí)行完后隨即返回原調(diào)用的進(jìn)程. 在調(diào)用system()期間SIGCHLD 信號(hào)會(huì)被暫時(shí)擱置,SIGINT 和SIGQUIT 信號(hào)則會(huì)被忽略.
返回值:
1、如果 system()在調(diào)用/bin/sh 時(shí)失敗則返回127, 其他失敗原因返回-1.。
2、若參數(shù)string 為空指針(NULL), 則返回非零值.
3、如果system()調(diào)用成功則最后會(huì)返回執(zhí)行shell 命令后的返回值, 但是此返回值也有可能為system()調(diào)用/bin/sh 失敗所返回的127, 因此最好能再檢查errno 來確認(rèn)執(zhí)行成功.
附加說明:在編寫具有 SUID/SGID 權(quán)限的程序時(shí)請(qǐng)勿使用system(), system()會(huì)繼承環(huán)境變量, 通過環(huán)境變量可能會(huì)造成系統(tǒng)安全的問題.
范例
#include <stdlib.h>main(){ system("ls -al /etc/passwd /etc/shadow");}
執(zhí)行:
-rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd-r--------- 1 root root 572 Sep 2 15 :34 /etc/shadow
C語(yǔ)言vfork()函數(shù):建立新的進(jìn)程
頭文件:
#include <unistd.h>
定義函數(shù):
pid_t vfork(void);
函數(shù)說明:
vfork()會(huì)產(chǎn)生一個(gè)新的子進(jìn)程, 其子進(jìn)程會(huì)復(fù)制父進(jìn)程的數(shù)據(jù)與堆棧空間, 并繼承父進(jìn)程的用戶代碼,組代碼, 環(huán)境變量、已打開的文件代碼、工作目錄和資源限制等。
Linux 使用copy-on-write(COW)技術(shù), 只有當(dāng)其中一進(jìn)程試圖修改欲復(fù)制的空間時(shí)才會(huì)做真正的復(fù)制動(dòng)作, 由于這些繼承的信息是復(fù)制而來, 并非指相同的內(nèi)存空間, 因此子進(jìn)程對(duì)這些變量的修改和父進(jìn)程并不會(huì)同步。
此外,子進(jìn)程不會(huì)繼承父進(jìn)程的文件鎖定和未處理的信號(hào)。
注意:Linux 不保證子進(jìn)程會(huì)比父進(jìn)程先執(zhí)行或晚執(zhí)行,因此編寫程序時(shí)要留意死鎖或競(jìng)爭(zhēng)條件的發(fā)生。
返回值:如果 vfork()成功則在父進(jìn)程會(huì)返回新建立的子進(jìn)程代碼(PID), 而在新建立的子進(jìn)程中則返回0. 如果vfork 失敗則直接返回-1, 失敗原因存于errno 中.
錯(cuò)誤代碼:
1、EAGAIN:內(nèi)存不足.
2、ENOMEM:內(nèi)存不足, 無法配置核心所需的數(shù)據(jù)結(jié)構(gòu)空間.
范例
#include <unistd.h>main(){ if(vfork() == 0) { printf("This is the child process/n"); } else { printf("This is the parent process/n"); }}
執(zhí)行:
this is the parent process this is the child process
新聞熱點(diǎn)
疑難解答
圖片精選