>시스템 튜토리얼 >리눅스 >방법론: Linux 프로세스의 종료 방법을 이해합니다.

방법론: Linux 프로세스의 종료 방법을 이해합니다.

王林
王林앞으로
2023-12-31 13:27:271314검색
소개 프로세스가 중간에 종료되거나 종료되면 커널은 프로세스가 점유하고 있는 시스템 리소스를 해제해야 합니다. 여기에는 프로세스가 실행되는 동안 열린 파일, 요청된 메모리 등이 포함됩니다.
프로세스 종료

Linux에서 프로세스 종료는 정상 종료와 비정상 종료의 두 가지 유형으로 나뉩니다.

1.정상적으로 종료

a. main() 함수에서 return을 실행합니다.

b.exit() 함수를 호출하세요

c._exit() 함수를 호출하세요

2.비정상적으로 종료

a.기능에 대해 전화

b. 프로세스가 신호를 받고, 신호로 인해 프로그램이 종료됩니다.

어떤 종료 방법을 사용하든 시스템은 결국 커널에서 동일한 코드를 실행합니다. 이 코드는 프로세스에서 사용하는 열린 파일 설명자를 닫고 프로세스가 차지하는 메모리 및 기타 리소스를 해제하는 데 사용됩니다.

여러 종료 방법 비교

1. 퇴실과 귀환의 차이점:

exit는 매개변수가 있는 함수입니다. 종료가 실행된 후 시스템에 제어권이 넘겨집니다

return은 함수가 실행된 후의 반환입니다. renturn이 실행된 후 제어권은 호출 함수로 넘겨집니다.

2. 종료와 중단의 차이점:

exit는 프로세스의 정상적인 종료입니다

약 비정상 종료입니다.

exit() 및 _exit() 함수

exit 및 _exit 함수는 모두 프로세스를 종료하는 데 사용됩니다. 프로그램이 exit 또는 _exit를 실행하면 시스템은 무조건 나머지 모든 작업을 중지하고 다양한 데이터 구조를 지우고 프로세스 실행을 종료합니다.

exit는 헤더 파일 stdlib.h에 선언되어 있고, _exit()는 unistd.h 헤더 파일에 선언되어 있습니다. Exit의 매개변수인 exit_code가 0이면 프로세스가 정상적으로 종료된다는 뜻이고, 다른 값이면 프로그램 실행 중에 오류가 발생한다는 뜻이다.

exit()와 _exit()의 차이점

_exit()는 실행 후 즉시 커널로 돌아가는 반면, exit()는 먼저 일부 정리 작업을 수행한 다음 제어권을 커널에 넘깁니다.

_exit 함수가 호출되면 프로세스의 모든 파일 설명자를 닫고 메모리 및 기타 커널 정리 기능을 정리하지만 스트림(stdin, stdout, stderr...)을 새로 고치지는 않습니다. _exit 함수 사이 _exit를 호출하고 호출하기 전에 스트림을 플러시하는 _exit의 래퍼입니다.

exit() 함수와 _exit() 함수의 가장 큰 차이점은 exit() 함수는 종료 시스템을 호출하기 전에 파일의 열린 상태를 확인하고 파일 버퍼의 내용을 파일에 다시 쓴다는 것입니다. 리눅스 표준 함수 라이브러리에는 '버퍼드 I/O'라는 연산이 있기 때문에, 열린 파일 각각에 대응하는 메모리에 버퍼가 있다는 것이 특징이다. 파일을 읽을 때마다 여러 레코드를 계속해서 읽으므로 다음에 파일을 읽을 때 메모리 버퍼에서 직접 읽을 수 있습니다. 마찬가지로 파일을 쓸 때마다 메모리에만 기록됩니다. 특정 조건(예: 특정 숫자에 도달하거나 특정 문자를 만나는 등)이 충족되면 버퍼의 내용이 즉시 파일에 기록됩니다. 이 기술은 파일 읽기 및 쓰기 속도를 크게 향상시키지만 프로그래밍에 약간의 문제를 가져오기도 합니다. 예를 들어, 파일에 쓴 것으로 생각되는 데이터가 있는데, 실제로는 특정 조건을 만족하지 않기 때문에 버퍼에만 저장되어 있는 경우가 있는데, 이때 _exit() 함수를 사용하면 바로 종료됩니다. 프로세스와 버퍼의 데이터가 손실됩니다. 따라서 데이터의 무결성을 보장하려면 exit() 함수를 사용해야 합니다.

함수 예시를 통해 이들 간의 차이점을 살펴보겠습니다.

함수 예시 1:exit.c

으아악

실행 결과는 다음과 같습니다.

으아악

함수 예시 2: _exit.c

으아악

실행 결과는 다음과 같습니다.

으아악

printf 함수는 버퍼링된 I/O를 사용합니다. 이 함수는 "n" 개행 문자를 만날 때 자동으로 버퍼에서 레코드를 읽습니다. 따라서 exit()는 버퍼에 데이터를 쓴 후 종료되는 반면, _exit() 함수는 직접 종료됩니다.

함수 예제 2에서 printf("This is the content in buffer");를 printf("This is the content in buffern")로 변경할 수도 있습니다(즉, printf 끝에 n을 추가하여 결과를 확인하세요). 왜 이런 일이 일어나는 걸까요? )

부모 프로세스와 자식 프로세스의 종료 순서가 다르면 결과도 달라집니다

1. 상위 프로세스가 하위 프로세스보다 먼저 종료됩니다.

이 상황은 앞서 사용했던 고아 프로세스입니다. 상위 프로세스가 먼저 종료되면 시스템은 init 프로세스가 하위 프로세스를 인수하도록 합니다.

2. 자식 프로세스는 부모 프로세스보다 먼저 종료되며, 부모 프로세스는 대기 함수를 호출하지 않습니다

이 경우 하위 프로세스는 좀비 상태에 들어가고 시스템이 다시 시작될 때까지 그대로 유지됩니다. 자식 프로세스가 좀비 상태에 있을 때 커널은 부모 프로세스의 프로세스에 대해 필요한 일부 정보만 저장합니다. 이때 자식 프로세스는 항상 리소스를 점유하게 되며, 시스템이 생성할 수 있는 최대 프로세스 수도 감소하게 됩니다.

좀비의 상태는 어떤가요?

종료되었지만 그 부모 프로세스가 아직 그 여파를 처리하지 않은 프로세스(종료된 자식 프로세스에 대한 정보를 얻고 여전히 점유하고 있는 리소스를 해제하는 것)를 좀비 프로세스라고 합니다.

3. 자식 프로세스는 부모 프로세스보다 먼저 종료되고, 부모 프로세스는 대기 함수를 호출합니다

이때 부모 프로세스는 자식 프로세스가 끝날 때까지 기다립니다.

위 내용은 방법론: Linux 프로세스의 종료 방법을 이해합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 linuxprobe.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제