방법론: Linux 프로세스의 종료 방법을 이해합니다.
소개 | 프로세스가 중간에 종료되거나 종료되면 커널은 프로세스가 점유하고 있는 시스템 리소스를 해제해야 합니다. 여기에는 프로세스가 실행되는 동안 열린 파일, 요청된 메모리 등이 포함됩니다. |
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Linux 터미널에서 Python 사용 ...

언어의 멀티 스레딩은 프로그램 효율성을 크게 향상시킬 수 있습니다. C 언어에서 멀티 스레딩을 구현하는 4 가지 주요 방법이 있습니다. 독립 프로세스 생성 : 여러 독립적으로 실행되는 프로세스 생성, 각 프로세스에는 자체 메모리 공간이 있습니다. 의사-다일리트 레딩 : 동일한 메모리 공간을 공유하고 교대로 실행하는 프로세스에서 여러 실행 스트림을 만듭니다. 멀티 스레드 라이브러리 : PTHREADS와 같은 멀티 스레드 라이브러리를 사용하여 스레드를 만들고 관리하여 풍부한 스레드 작동 기능을 제공합니다. COROUTINE : 작업을 작은 하위 작업으로 나누고 차례로 실행하는 가벼운 다중 스레드 구현.

Web.xml 파일을 열려면 다음 방법을 사용할 수 있습니다. 텍스트 편집기 (예 : 메모장 또는 문자 메시지)를 사용하여 통합 개발 환경 (예 : Eclipse 또는 NetBeans)을 사용하여 명령을 편집하십시오 (Windows : Notepad Web.xml; Mac/Linux : Open -A Texted web.xml).

Linux 시스템과 함께 제공되는 Python 통역사를 제거하는 문제와 관련하여 많은 Linux 배포판이 설치 될 때 Python 통역사를 사전 설치하고 패키지 관리자를 사용하지 않습니다 ...

Linux는 서버 관리, 임베디드 시스템 및 데스크탑 환경으로 사용되는 것이 가장 좋습니다. 1) 서버 관리에서 Linux는 웹 사이트, 데이터베이스 및 응용 프로그램을 호스팅하는 데 사용되어 안정성과 안정성을 제공합니다. 2) 임베디드 시스템에서 Linux는 유연성과 안정성으로 인해 스마트 홈 및 자동차 전자 시스템에서 널리 사용됩니다. 3) 데스크탑 환경에서 Linux는 풍부한 응용 프로그램과 효율적인 성능을 제공합니다.

Debianlinux는 안정성과 보안으로 유명하며 서버, 개발 및 데스크탑 환경에서 널리 사용됩니다. 현재 Debian 및 Hadoop과 직접 호환성에 대한 공식 지침이 부족하지만이 기사에서는 Debian 시스템에 Hadoop를 배포하는 방법을 안내합니다. 데비안 시스템 요구 사항 : Hadoop 구성을 시작하기 전에 Debian 시스템이 Hadoop의 최소 작동 요구 사항을 충족하는지 확인하십시오. 여기에는 필요한 JAVA 런타임 환경 (JRE) 및 Hadoop 패키지 설치가 포함됩니다. Hadoop 배포 단계 : 다운로드 및 unzip hadoop : 공식 Apachehadoop 웹 사이트에서 필요한 Hadoop 버전을 다운로드하여 해결하십시오.

GO를 사용하여 Oracle 데이터베이스에 연결할 때 Oracle 클라이언트를 설치해야합니까? GO에서 개발할 때 Oracle 데이터베이스에 연결하는 것이 일반적인 요구 사항입니다 ...

Root로 MySQL에 로그인 할 수없는 주된 이유는 권한 문제, 구성 파일 오류, 암호 일관성이 없음, 소켓 파일 문제 또는 방화벽 차단입니다. 솔루션에는 다음이 포함됩니다. 구성 파일의 BAND-ADDRESS 매개 변수가 올바르게 구성되어 있는지 확인하십시오. 루트 사용자 권한이 수정 또는 삭제되어 재설정되었는지 확인하십시오. 케이스 및 특수 문자를 포함하여 비밀번호가 정확한지 확인하십시오. 소켓 파일 권한 설정 및 경로를 확인하십시오. 방화벽이 MySQL 서버에 연결되는지 확인하십시오.
