>백엔드 개발 >C++ >이 코드에서 `fork()`가 예상보다 더 많은 점을 생성하는 이유는 무엇입니까?

이 코드에서 `fork()`가 예상보다 더 많은 점을 생성하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-04 01:31:02844검색

Why Does `fork()` Produce More Dots Than Expected in This Code?

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>

이 코드는 두 번 분기되고 각 프로세스가 하나의 점을 인쇄하므로 출력으로 6개의 점을 생성해야 합니다. 그런데 놀랍게도 8개의 도트가 출력됩니다. 왜 이런 일이 발생합니까?

Fork() 및 프로세스 복제

fork() 함수는 현재 프로세스를 거의 완벽하게 복제합니다. 가장 눈에 띄는 차이점은 상위 프로세스와 하위 프로세스 간에 반환 값이 다르다는 것입니다.

이 코드에서 fork() 호출은 원래 프로세스와 3개의 하위 프로세스 등 4개의 프로세스를 생성합니다. 각 프로세스는 생성될 때 처음 6개의 점을 고려하여 점을 인쇄합니다.

버퍼 출력

그러나 한 가지 문제가 더 있습니다. printf()는 버퍼를 사용하여 출력이 플러시되거나 프로세스가 종료될 때까지 출력을 저장합니다. 이 코드에서는 프로세스가 종료될 때까지 출력이 플러시되지 않습니다.

결과적으로 두 번째 포크 중에 원래 프로세스와 첫 번째 하위 프로세스의 점이 버퍼에 남아 있습니다. 나머지 4개의 프로세스(첫 번째 분기에서 2개, 두 번째 분기에서 2개)가 종료되면 버퍼를 플러시하여 점이 인쇄됩니다. 이렇게 하면 총 출력이 8개의 도트가 됩니다.

버퍼 출력 방지

이 동작을 방지하려면 fflush(stdout)를 호출할 수 있습니다. 각 printf() 호출 후에 출력이 즉시 플러시되도록 합니다. 그러나 이는 일부 시나리오에서는 성능에 영향을 미칠 수 있습니다.

위 내용은 이 코드에서 `fork()`가 예상보다 더 많은 점을 생성하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.