(1)fork()的定義

fork()函式是Unix中派生新程序的唯一方法,宣告如下:

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

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

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

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

(2)fork()的實質過程

父程序中在呼叫fork()派生新程序,實際上相當於建立了程序的一個拷貝;即在fork()之前的程序擁有的資源會被複制到新的程序中去。網路伺服器在處理併發請求時,也可以採取這種派生新程序的方式: 父程序呼叫accept()後呼叫fork()來處理每一個連線。那麼,所接受的已連線的套介面隨後就在父子程序中共享。通常來說,子程序會在這連線套介面中讀和寫操作,父程序則關閉這個已連的套介面(可以參考:http://blog.csdn.net/moxiaomomo/article/details/6791763)

(3)fork()的用法

fork()有兩個典型用法:(1)一個程序進行自身的複製,這樣每個副本可以獨立的完成具體的操作,在多核處理器中可以並行處理資料。這也是網路伺服器的其中一個典型用途,多程序處理多連線請求。 (2)一個程序想執行另一個程式。比如一個軟體包含了兩個程式,主程式想調起另一個程式的話,它就可以先呼叫fork來建立一個自身的拷貝,然後通過exec函式來替換成將要執行的新程式。