linux創建子進程--fork()方法


(1)fork()的定義

fork()函數是Unix中派生新進程的唯一方法,聲明如下:

 

  1. #include <unistd.h>  
  2.   
  3. pid_t fork(void);  


我們需要理解的是,調用一次fork()方法,該方法會返回兩次。一次是在調用進程(也就是派生出的子進程的父進程)中返回一次,返回值是新派生的進程的進程ID。一次是在子進程中返回,返回值是0,代表當前進程為子進程。如果返回值為-1的話,則代表在派生新進程的過程中出錯。

 

那么在程序中,我們就可以根據此返回值來判斷當前進程是父進程還是子進程,來實現一些具體的操作。例如:

 

  1. int main()  
  2. {  
  3.     pid_t pid;  
  4.   
  5.     if((pid = fork()) = 0)  
  6.     {  
  7.         // TODO: 在子進程中實現具體操作  
  8.         // ...  
  9.         exit(0); // 結束子進程  
  10.     }  
  11.   
  12.     // TODO: 在調用進程(父進程)實現具體操作  
  13. }  

(2)fork()的實質過程

 

父進程中在調用fork()派生新進程,實際上相當於創建了進程的一個拷貝;即在fork()之前的進程擁有的資源會被復制到新的進程中去。網絡服務器在處理並發請求時,也可以采取這種派生新進程的方式: 父進程調用accept()后調用fork()來處理每一個連接。那么,所接受的已連接的套接口隨后就在父子進程中共享。通常來說,子進程會在這連接套接口中讀和寫操作,父進程則關閉這個已連的套接口(可以參考:http://blog.csdn.net/moxiaomomo/article/details/6791763)

(3)fork()的用法

fork()有兩個典型用法:(1)一個進程進行自身的復制,這樣每個副本可以獨立的完成具體的操作,在多核處理器中可以並行處理數據。這也是網絡服務器的其中一個典型用途,多進程處理多連接請求。 (2)一個進程想執行另一個程序。比如一個軟件包含了兩個程序,主程序想調起另一個程序的話,它就可以先調用fork來創建一個自身的拷貝,然后通過exec函數來替換成將要運行的新程序。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM