이 섹션에서는 C/C++의 단일 프로그램에서 좀비 및 고아 프로세스를 실행하는 방법을 알아봅니다. 본론으로 들어가기 전에 먼저 좀비 프로세스와 고아 프로세스가 무엇인지 이해해 봅시다.
좀비 프로세스는 실행이 완료되었지만 아직 공간이 남아 있는 프로세스입니다. 프로세스 테이블의 항목입니다. 좀비 프로세스는 일반적으로 하위 프로세스에서 발생합니다. 왜냐하면 상위 프로세스는 여전히 하위 프로세스의 종료 상태를 읽어야 하기 때문입니다. 대기 시스템 호출을 사용하여 이 작업이 완료되면 좀비 프로세스가 프로세스 테이블에서 제거됩니다. 이를 좀비 프로세스 수확이라고 합니다.
고아 프로세스는 상위 프로세스가 종료되거나 완료되었음에도 여전히 실행 중인 프로세스입니다. 프로세스는 의도적으로 또는 의도하지 않게 고아가 될 수 있습니다.
의도적으로 분리된 프로세스는 수동 지원 없이 백그라운드에서 실행됩니다. 이는 일반적으로 무기한 실행되는 서비스를 시작하거나 사용자가 눈치채지 못하게 장기 실행 작업을 완료하기 위해 수행됩니다.
고아 프로세스는 상위 프로세스가 충돌하거나 종료될 때 실수로 생성됩니다. 의도하지 않은 고아 프로세스를 방지하려면 프로세스 그룹 메커니즘을 사용하십시오.
이제 아래 코드에서는 좀비 프로세스와 고아 프로세스를 동시에 실행해 보겠습니다. 여기에는 하위 프로세스가 있는 상위 프로세스가 있고 이 하위 프로세스에는 또 다른 하위 프로세스가 있습니다. 컨트롤이 하위 프로세스에 삽입되면 상위 프로세스를 완료할 수 있도록 5초 동안 실행을 중지합니다. 따라서 하위 프로세스는 고아 프로세스가 됩니다. 그러면 손자 프로세스가 좀비 프로세스로 변환됩니다. 손자 프로세스는 상위 프로세스(메인 프로세스의 하위 프로세스)가 1초 동안 휴면 상태일 때 실행을 완료합니다. 따라서 손자 프로세스는 종료를 호출하지 않으며 해당 항목이 프로세스 테이블에 존재하게 됩니다.
#include <stdio.h> #include <unistd.h> int main() { int x = fork(); //create child process if (x > 0) //if x is non zero, then it is parent process printf("Inside Parent---- PID is : %d</p><p>", getpid()); else if (x == 0) { //for chile process x will be 0 sleep(5); //wait for some times x = fork(); if (x > 0) { printf("Inside Child---- PID :%d and PID of parent : %d</p><p>", getpid(), getppid()); while(1) sleep(1); printf("Inside Child---- PID of parent : %d</p><p>", getppid()); }else if (x == 0) printf("Inside grandchild process---- PID of parent : %d</p><p>", getppid()); } return 0; }
soumyadeep@soumyadeep-VirtualBox:~$ ./a.out Inside Parent---- PID is : 3821 soumyadeep@soumyadeep-VirtualBox:~$ Inside Child---- PID :3822 and PID of parent : 686 Inside grandchild process---- PID of parent : 3822 soumyadeep@soumyadeep-VirtualBox:~$
위 내용은 단일 C 프로그램에서 좀비 및 고아 프로세스를 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!