一道关于 fork 的笔试题
生活随笔
收集整理的這篇文章主要介紹了
一道关于 fork 的笔试题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目
閱讀下面的代碼,顯示終端會打印出幾個 hello world?
#include?<sys/types.h> #include?<unistd.h> #include?<stdio.h> #include?<stdlib.h>int?main() {fork();fork();fork();printf("hello?world\n");exit(0); }答案是多少呢?我們一起分析一下。
原理分析
關于 fork
fork() 函數會創建一個新的子進程。子進程得到與父進程用戶級虛擬地址空間相同的一份副本,包括代碼段數據段、堆、共享庫、用戶棧等。
fork 調用一次,返回兩次:一次是返回到父進程。一次是返回到新創建的子進程。調用返回后,父進程和子進程各自繼續執行后邊的指令。
父進程和子進程并發獨立運行,內核能夠以任意方式交替執行它們的指令。
父進程和子進程有相同但是獨立的地址空間。
父進程和子進程之間共享文件。即子進程會繼承父進程所有打開的文件。
fork 嵌套分析
我們可以通過畫圖,來理解帶有嵌套 fork 調用的程序。
為了方便看出是哪個 fork 執行,在圖中用標號進行了標注。
第一個 fork 執行了 1 次。第二 fork 執行了 2 次,第三個 fork 執行了 4 次。最終有 8 個進程運行程序。
從而 printf 函數被調用了 8 次。
結果
根據以上分析可知,代碼最終打印 8 次 hello world。
我們可以在 PC 上驗證一下,編譯、執行后的輸出結果:
$?gcc?fork.c $?./a.out hello?world hello?world hello?world hello?world hello?world hello?world hello?world hello?world實際結果與分析相同。
看來 fork() 不僅要會用,還要理解其背后的原理,還有就是掌握分析問題的方法。
如此,才能在遇到的問題的時候,從容不迫。
加油~
總結
以上是生活随笔為你收集整理的一道关于 fork 的笔试题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SQL插入多行数据
- 下一篇: 在腾讯做嵌入式是怎么样的