您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關Linux進程控制的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
Linux進程控制詳解及實例
常用函數:
fork() 通過復制調用進程來建立新的進程,是最基本的進程建立操作。
exec 包括一系列的系統調用,其中每個系統調用都完成相同的功能,即通過用一個新的程序覆蓋原內存空間,來實現進程的轉變。各種exec系統調用之間的區別僅在于它們的參數構造不同。
wait() 它提供了初級的進程同步措施,能使一個進程等待,直到另一個進程結束為止。
exit() 常用來終止一個進程的運行。
進程的建立
如果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命令的代碼。
關于“Linux進程控制的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。