【作業系統】linux建立子進程–fork()方法

來源:互聯網
上載者:User

(1)fork()的定義

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

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

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

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

int main(){    pid_t pid;    if((pid = fork()) = 0)    {        // TODO: 在子進程中實現具體操作        // ...        exit(0); // 結束子進程    }    // TODO: 在調用進程(父進程)實現具體操作}

(2)fork()的實質過程

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

(3)fork()的用法

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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.