您好,登錄后才能下訂單哦!
這篇文章主要介紹了Linux中fork執行的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
Linux 中fork的執行的實例詳解
先看看一段fork的程序
int main() { pid_t pid; 語句 a; pid = fork(); 語句 b; }
1.當程序運行到 pid = fork()時,這個進程馬上分裂(fork的中文意思)成兩個進程,我們稱為父進程和子進程,子進程是父進程的副本,副本的意思是子進程把父進程的數據空間,堆和棧都復制一遍給自己用,這要求在內存給子進程分配和父進程同樣大的存儲空間,這樣,父,子進程擁有相同的數據,但不會共享存儲空間,他們只是共享正文段。
2.apue2這樣說fork的執行:fork函數被調用一次,但返回兩次,兩次返回的唯一區別是子進程的返回值是0,而父進程的返回值則是子進程的進程ID。一直很難理解調用一次,返回兩次這句話,我想這樣理解可能更好:fork函數被調用一次,但執行兩次,父進程執行一次返回子進程的進程ID,子進程執行一次返回0.
3.fork完后,子進程和父進程繼續執行fork調用之后的語句,是先執行父進程還是先執行子進程呢?apue2給出了答案:一般來說,在fork之后是父進程先執行還是子進程先執行是不確定的。這取決于所使用的調度算法。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“Linux中fork執行的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。