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