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之后是父進程先執行還是子進程先執行是不確定的。這取決于所使用的調度算法。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
新聞熱點
疑難解答