首頁 >後端開發 >C++ >為什麼簡單的 fork() 迴圈產生八個點而不是兩個?

為什麼簡單的 fork() 迴圈產生八個點而不是兩個?

Susan Sarandon
Susan Sarandon原創
2024-11-04 02:04:02531瀏覽

Why does the simple fork() loop produce eight dots instead of two?

fork() 中意外分支的奇怪案例

考慮以下使用fork() 原語建立子程序的程式碼片段:

<code class="C">#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>

int main(void)
{
    int i;
    for(i = 0; i < 2; i++)
    {
        fork();
        printf(".");
    }
    return 0;
}</code>

令人驚訝的是,執行這個程式會產生八個輸出點,比您最初預期的多六個。為什麼會出現這種情況?

揭開隱藏進程

為了解開這個謎團,讓我們深入研究 fork() 的操作。 fork() 建立目前程序的副本,從而產生父行程和子程序。

最初,有一個進程,它分叉為兩個進程。這兩個過程都會增量執行 for 循環,每次列印一個點。在第二次迭代中,每個進程再次分叉,總共創建四個進程。這四個進程在終止前列印一個點。

緩衝輸出和延遲出現

但是,printf() 緩衝其輸出,這表示它會在發送之前累積多個列印內容立刻。當所有四個進程都印出第二個點時,它們會被緩衝。這就是偷偷摸摸的效果出現的地方。

在 fork() 上,緩衝的點由子程序繼承。因此,當每個子程序退出時,其緩衝點出現在輸出流上。將這四個延遲點添加到增量列印的四個點中,總共會達到意想不到的八個點。

避免緩衝點

要繞過此緩衝行為,建議呼叫fflush(標準輸出);在每個 printf() 語句之後。這會強制立即發送輸出,確保顯示預期的點數。

以上是為什麼簡單的 fork() 迴圈產生八個點而不是兩個?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn