歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux基礎 >> Linux技術 >> linux之父子進程的輸出

linux之父子進程的輸出

日期:2017/3/3 11:52:27   编辑:Linux技術

首先,我們來回憶一下父進程與子進程,前幾節講了如何創建子進程,像這樣的,pid_t id = fork(); 這樣我們就創建好了一個子進程,然而fork()函數的返回值是什麼呢?這裡要記住:子進程返回0,父進程返回子進程的pid,如果創建失敗的話就返回-1.由於是父進程創建的子進程,那麼子進程就繼承自父進程。比如,子進程繼承了父進程的數據空間,堆和棧的副本。但是,父子進程是不是就共享同一片地址空間呢?答案是否定的。這就引出了我們前幾節講的虛擬地址的內容。回憶一下:

它們就是父子進程所對應的地址空間,雖然它們的虛擬地址是一樣的,但是它們的物理地址卻是不一樣的。(這幅圖的詳細介紹見本博客《linux之地址空間》)

父子進程不共享存儲空間,只共享代碼段。

下面看一個例子:

想一想這個代碼運行的結果是什麼呢?

很多人看了這個代碼之後以為它會輸出4條語句,但其實不然。我們來分析一下其中的奧秘吧,嘿嘿。。。

首先,父進程創建子進程,則父子進程各打印一條自己的pid,打印完之後i++;i++;這時父進程又重新創建子進程,上一級的子進程又進入到父進程,從而又創建子進程,這樣i=1時相當於父子進程各創建了2個進程,即第二級創建了4個進程,所以進程數= 2+4=6.

結果如下哦:

這個圖是不是有點像二叉樹呢?那麼當i = 10的時候呢?

經過上述的分析推理得知它的結果是這樣的:2+2^2+2^3+……+2^10=2046當i = n時,公式為:2+2^2+2^3+……+2^n= 2*(1-2^n)/(1-2);

Copyright © Linux教程網 All Rights Reserved