unix 編程進程控制:
fork函數
fork創立子進程,子進程是父進程的正本,會失掉父進程數據空間、堆、棧的正本。
然後文件的共享這塊也比擬復雜,父進程和子進程各自都有文件描繪符表,但是文件表示公用的(而普通兩個進程,文件表是每個進程獨有的),也就是說文件的偏移量是分歧。一個文件在父進程中翻開,在子進程中也會被翻開一遍,因而假如在子進程中不運用這個文件,先要close這個文件。
vfork函數
和fork函數有如下區別:
1:vfork子進程先執行,並且子進程調用exec函數
2:vfork子進程不會copy父進程的地址空間,也就是會公用。
exit函數
exit函數會封閉所以I/O流
wait waitpid函數
假如一切子進程還在運轉,阻塞
假如一個子進程已終止,父進程立即獲取其終止形態,前往。
假如沒有任何子進程,出錯前往。
waitpid 函數
1.pid==-1 等候任何一子進程
2. pid > 0 等候指定pid
3.pid==0 等候組ID等於調用進程組ID的任一進程
4.等候組ID等於pid相對值的任一子進程
當然這兩個函數也可以設置成不阻塞
exec函數
fork進程後,子進程往往會調用exec函數,exec函數不創立進程,進程ID不變。exec只是用磁盤上一個新順序交換了以後進程的注釋段,數據段,堆段,棧段。
execl ,execv,execle,execve,execlp,execvp,fexecve
這幾個函數其中
l代表list,每個命令都是一個獨立參數,最後一個參數需求寫成(char *)0
char*pathname ,char *arg0,...char *argn, (char *)0
p代表filename作為參數,從PATH中尋覓可執行文件。
v代表vector,是一個數組,參數從數組中失掉。
e代表環境,可以給子進程指定一個環境變量。
還有一點,之前有FD_CLOEXEC標志,代表執行exec是就封閉該描繪符。由於fork子進程默許翻開在父進程翻開的描繪符。
更改用戶ID和組ID
這個需求留意,進程能否有權限讀寫每個文件,次要看進程的無效用戶ID。
特別留意一點,當順序文件設置了設置用戶ID位。exec函數執行這個順序時,會設置依據這個順序文件的uid無效用戶ID。假如
沒有設置用戶ID位,exec函數不會改動無效用戶ID,維持現有值。
解析器文件
#! pathname 參數
文件中遇到這種就是解釋器文件
當執行execl函數的時分,會先執行這個命令。
函數system
其實就是相似在shell中打命令,其實就是fork一個進程,然後執行exec
進程調度
可以運用nice函數設置進程的優先級
感激閱讀,希望能協助到大家,謝謝大家對本站的支持!
【unix 編程進程控制詳細引見】的相關資料介紹到這裡,希望對您有所幫助! 提示:不會對讀者因本文所帶來的任何損失負責。如果您支持就請把本站添加至收藏夾哦!