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 중국어 웹사이트의 기타 관련 기사를 참조하세요!