(1)fork()的定義服務器
fork()函數是Unix中派生新進程的惟一方法,聲明以下:網絡
咱們須要理解的是,調用一次fork()方法,該方法會返回兩次。一次是在調用進程(也就是派生出的子進程的父進程)中返回一次,返回值是新派生的進程的進程ID。一次是在子進程中返回,返回值是0,表明當前進程爲子進程。若是返回值爲-1的話,則表明在派生新進程的過程當中出錯。併發
那麼在程序中,咱們就能夠根據此返回值來判斷當前進程是父進程仍是子進程,來實現一些具體的操做。例如:函數
(2)fork()的實質過程spa
父進程中在調用fork()派生新進程,實際上至關於建立了進程的一個拷貝;即在fork()以前的進程擁有的資源會被複制到新的進程中去。網絡服務器在處理併發請求時,也能夠採起這種派生新進程的方式: 父進程調用accept()後調用fork()來處理每個鏈接。那麼,所接受的已鏈接的套接口隨後就在父子進程中共享。一般來講,子進程會在這鏈接套接口中讀和寫操做,父進程則關閉這個已連的套接口(能夠參考:http://blog.csdn.net/moxiaomomo/article/details/6791763).net
(3)fork()的用法blog
fork()有兩個典型用法:(1)一個進程進行自身的複製,這樣每一個副本能夠獨立的完成具體的操做,在多核處理器中能夠並行處理數據。這也是網絡服務器的其中一個典型用途,多進程處理多鏈接請求。 (2)一個進程想執行另外一個程序。好比一個軟件包含了兩個程序,主程序想調起另外一個程序的話,它就能夠先調用fork來建立一個自身的拷貝,而後經過exec函數來替換成將要運行的新程序。接口