Posted on 2009-04-15 22:48
Prayer 閱讀(2938)
評論(1) 編輯 收藏 引用 所屬分類:
LINUX/UNIX/AIX
fork () 的作用是什么?換句話說,你用 fork () 的目的是什么?
――是為了產生一個新的進程,地球人都知道
產生一個什么樣的進程?
――和你本來調用 fork () 的那個進程基本一樣的進程,其實就是你原來進程的副本
真的完全一樣嗎?
――當然不能完全一樣,你要兩個除了 pid 之外其它一模一樣的進程干什么,就算 cpu mem
再多也不用這么擺譜吧?
哪里不一樣?
――當然最重要的是 fork () 之后執行的代碼不一樣,you know, i know
怎么實現呢?
――如果是 Windows,它會讓你在 fork () 里面提供一大堆東西,指明這個那個什么的……
我用的是 unix 啊
――所以很簡單,unix 會讓兩個進程(不錯,原來是一個,unix 替你復制了一個,現在有兩個):
在 fork () 之后產生不同:返回值不同。其中一個進程(使用新的 pid)里面的 fork () 返回零,
這個進程就是“子進程”;而另一個進程(使用原來的 pid)中的 fork () 返回前面那個子進程的
pid,他自己被稱為“父進程”
然后呢?
――寫代碼的人又不笨,當然就根據返回值是否非零來判斷了,現在我是在子進程里面呢,還是在
父進程里面?在子進程里面就執行子進程該執行的代碼,在父進程里面就執行父進程的代碼……
有鐵桿 windows fans 借此說明,windows 好啊,子進程用子進程的代碼,父進程用父進程的,
你 unix 笨了吧,子進程包含父進程、子進程的代碼,父進程包含父進程子進程的代碼,豈不是多"
占用內存了嗎?
共享同一代碼段,增加的只是全局共享數據和對文件描述符的引用等,另外就是堆棧。你一個代碼:
長達 10M 的進程,fork () 出三四個子進程,只是增加一點內存占用(如果你沒有使用很多全局變量
的話),而不是占用 40M 以上的內存。
父進程里面有個變量 var,子進程里面也有個變量 var
linux 是多用戶和多進程的操作系統,進程在操作系統中的創建,都會生成一個進程描述塊,描述當前進程的所有信息,包括,數據段、代碼段、堆棧段的地址,當前進程的環境變量,文件描述符等。
fork函數過程:操作系統先創建一個進程描述塊,然后把父進程的所有進程描述符的信息精確拷貝過來,和父進程一樣(除了進程ID不一樣外),代碼段共享,數據段和堆棧段復制,所有的寄存器的值全部精確拷貝,文件描述符也許精確拷貝。
fork的返回值,fork在父進程空間中返回子進程的PID,在子進程空間中返回0。