Linux進程控制詳解及實例
常用函數:
進程的建立
如果fork()調用成功,就會使內核建立一個新的進程,所建的新進程是調用fork()進程的副本。也就是說,新的進程運行與其創建者一樣的程序,其中的變量具有與創建進程變量相同的值。
系統調用fork()沒有參數,它返回一個pid_t類型的值pid。pid被用來區分父進程和子進程。在父進程中pid被置為一個非0的正整數;在子進程中,pid被置為0。
進程的運行
exec系列調用:
int execl(const char* path, const char *arg, ...); int execlp(const char * file, const char *arg, ...); int execle(const char *path, const char *arg, ..., char * const envp[]); int execv(const char* path, char *const argv[]); int execvp(const char* file, char * const argv[]);
由于參數的個數是任意的,所以必須用一個null指針來標記參數表的結尾。下面給出一個使用execl()和execv()調用來運行ls的例子:
/*execl的例子*/#include <stdio.h>#include <unistd.h>main(){ printf("Excuting ls/n"); execl("/bin/ls", "ls", "-l", NULL); /*如果execl返回,說明調用失敗*/ perror("execl failed to run ls"); exit(1);}/*execv的例子*/#include <stdio.h>#include <unistd.h>main(){ char *cmd[]={"ls", "-l", NULL}; execv("/bin/ls", cmd); perror("execv failed"); exit(1);}
系統調用execlp()和execvp()分別類似于系統調用execl()和execv(),它們的主要區別是:execlp()和execvp()的第一個參數指向的是一個簡單的文件名,而不是一個路徑名。它們通過檢索shell環境變量PATH指出的目錄,來得到該文件名的路徑前綴部分。
exec和fork()的聯用
通過聯用可以實現父進程運行一個與其不同的子進程,并且父進程不會被覆蓋。下面給出一個 exec和fork()聯用的例子:
#include <stdio.h>#include <unistd.h>main(){ int pid; /*fork子進程*/ pid = fork(); switch(pid){ case -1: perror("fork failed."); exit(1); case 0: execl("/bin/ls", "ls", "-l", NULL); perror("execl failed."); exit(1); default: wait(NULL); printf("ls completed./n"); exit(0); }}
在fork()調用之前,只有一個進程A,fork()調用后就有了進程A和B。A是父進程,它正在執行系統調用wait(),使進程A睡眠,直至進程B結束。同時進程B正在用execl裝入命令ls。exec調用后,進程B的程序被ls的代碼取代,執行ls命令的代碼。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
新聞熱點
疑難解答