처음 두 장에서는 프로세스 생성에 대해 배웠습니다. 이번 장에서는 Linux에서 프로세스를 종료하는 방법을 알아봅니다.
Linux에는 프로세스를 정상적으로 종료하는 3가지 방법과 비정상적으로 종료하는 2가지 방법이 있습니다.
1. 정상 종료:
a. 메인 함수에서 return을 호출하세요. 이는 종료를 호출하는 것과 동일합니다.
b. ANSIC의 이 함수 정의에 따라 호출되면 등록된 모든 종료 핸들이 실행되고 모든 표준 I/O 스트림이 꺼지며 파일 설명자 및 여러 프로세스(상위 프로세스) (하위 프로세스 포함), 작업 등은 처리되지 않으므로 Linux 시스템에서는 적합하지 않습니다.
c. _exit 함수를 호출하세요. 종료는 _exit에 의한 Linux 훈련이라고 하며 일부 Linux 관련 종료 핸들을 닫습니다.
2. 비정상 종료
a. 중단을 호출합니다. 이는 SIGABRT 신호를 형성하므로 두 번째 경우의 특별한 경우인 것 같습니다.
b. 프로세스는 특정 신호를 수신합니다. 이 신호는 프로세스 자체(예: 중단 기능)에 의해 생성될 수도 있고 다른 프로세스나 커널에서 올 수도 있습니다. 예를 들어 프로세스가 범위를 벗어난 메모리 주소에 액세스하려고 시도하거나 제수가 0인 경우 커널은 프로세스를 중단하는 신호를 생성합니다.
프로세스를 종료하기 위해 어떤 방법을 사용하든 결국 커널의 동일한 코드 조각이 실행됩니다. 이 코드는 프로세스에서 열린 모든 파일 설명자, 개인 액세스가 차지하는 비디오 메모리 등을 닫습니다.
exit 및 _exit 함수를 살펴보겠습니다
이 두 함수는 서로 다른 헤더 파일에 있습니다. 종료는 stdlib.h에 있고, _exit는 unistd.h에 있습니다
구체적인 통화 방법은 다음과 같습니다.
탈퇴 무효(int__status)
void_exit(int__status)
상태 매개변수는 종료 상태입니다.
다음 두 가지 코드를 살펴보겠습니다.
사진 1
사진 2
사진 3
사진 4
그림 1의 코드에는 n이 부족하여 테스트 종료 시 문장이 복사되지 않습니다. 이는 printf가 n을 추가하지 않으면 정보가 즉시 복사되지 않고 _exit가 출력을 강제하지 않기 때문입니다. 즉, 장치에 기록되지 않았고 printf/fprintf와 같은 호출로 인해 여전히 버퍼에 있는 데이터는 _exit 중에 삭제되지만 종료에서는 삭제되지 않습니다. . n이 있으면 직접 복사하세요. 이때는 exit/_exit
차이가 없습니다.남매 프로세스가 종료되는 순서가 다르면 결과도 달라집니다
1. 상위 프로세스가 하위 프로세스보다 먼저 종료됩니다.
이 상황을 우리는 고아 프로세스라고 부릅니다. 상위 프로세스가 먼저 종료되면 시스템은 init 프로세스가 하위 프로세스를 인수하도록 합니다.
2. 자식 프로세스는 부모 프로세스보다 먼저 종료되며, 부모 프로세스는 대기 함수를 호출하지 않습니다
이 경우 하위 프로세스는 좀비 상태에 들어가고 시스템이 다시 시작될 때까지 그대로 유지됩니다. 자식 프로세스가 좀비 상태에 있을 때 Linux에서는 저장하지 않고 종료됩니다. 커널은 부모 프로세스에 필요한 일부 프로세스 정보만 저장합니다. 이때 하위 프로세스는 여전히 리소스를 점유하며 시스템이 생성할 수 있는 최대 프로세스 수도 감소합니다.
좀비 상태란 무엇인가요?
오래 전에 종료되었지만 그 부모 프로세스가 아직 그 여파를 처리하지 않은 프로세스(종료된 자식 프로세스에 대한 정보를 얻고 여전히 점유하고 있는 리소스를 해제하는 것)를 좀비 프로세스(좀비)라고 합니다.
3. 하위 프로세스는 상위 프로세스보다 먼저 종료Linux에서는 저장하지 않고 종료되지만 상위 프로세스는 대기 함수를 호출합니다
이때 부모 프로세스는 자식 프로세스가 끝날 때까지 기다립니다.
위 내용은 Linux에서 프로세스 종료 방법: 정상 종료와 비정상 종료에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!