예제를 사용하여 C에서 getpid 함수 호출

Calling Getpid Function C With Examples



Getpid()는 해당 함수를 호출하는 프로세스의 프로세스 ID를 가져오는 데 사용되는 함수입니다. 초기 프로세스의 PID는 1이고 각각의 새 프로세스에는 새 Id가 할당됩니다. PID를 얻는 간단한 방법입니다. 이 기능은 고유한 프로세스 ID를 얻는 데만 도움이 됩니다.

아이디를 얻을 때 사용하는 함수

여기에는 두 가지 유형의 ID가 있습니다. 하나는 프로세스 PID의 현재 ID입니다. 반면 다른 하나는 상위 프로세스 PPID의 ID입니다. 이 두 함수는 모두 라이브러리에 정의된 내장 함수입니다. 이 라이브러리를 사용하지 않고 코드를 실행하는 동안 오류가 발생하고 실행이 중지될 수 있습니다.







C의 getpid() 함수

어떤 프로세스가 형성되어 실행 중일 때 고유한 id가 할당됩니다. 이것은 프로세스 ID입니다. 이 함수는 현재 호출된 프로세스의 ID를 반환하는 데 도움이 됩니다.



C의 getppid() 함수

이 id는 부모 프로세스/함수의 프로세스를 반환하는 데 유용합니다.



실시예 1
C 언어의 프로세스에서 PID의 예를 이해합니다. 텍스트 편집기와 명령을 실행해야 하는 Linux 터미널의 두 가지 도구가 필요합니다. 텍스트 편집기에서 파일을 만듭니다. 코드가 C 언어로 작성되었으므로 파일명 code1.c를 생성하였으므로 .c 확장자로 저장해야 합니다.





단일 라이브러리를 추가했습니다. 그런 다음 여기에서 메인 프로그램을 시작합니다. 메인 프로그램에서 내장 함수 getpid()를 호출합니다. 현재 프로세스의 id를 가져옵니다. 그리고 변수가 도입되어 할당됩니다. PID() 함수의 값이 이 변수에 저장되도록 이 변수를 사용하여 값을 인쇄합니다.



이제 이 파일의 내용을 Linux 터미널에서 실행하려고 합니다. 코드 전제 조건은 먼저 컴파일한 다음 실행하는 것입니다. 컴파일에는 GCC가 사용됩니다. 시스템에 GCC가 없으면 먼저 Sudo 명령을 사용하여 GCC를 설치해야 합니다.

이제 작성된 코드를 컴파일하십시오. 이것은 다음의 추가된 명령을 사용하여 수행할 수 있습니다.

$ GCC –o code1 code1.c

반면 -o는 명령에서 저장 파일을 여는 데 사용됩니다. 그런 다음 -o 뒤에 파일 이름을 씁니다.

컴파일 후 명령을 실행합니다.

$ ./코드1

위 이미지는 함수의 프로세스 ID를 보여줍니다.

실시예 2
이전 예에서는 PID를 사용합니다. 그러나 이 예에서는 PID와 PPID가 모두 사용됩니다. 이 함수의 소스 코드는 앞의 것과 거의 동일합니다. ID의 또 다른 추가가 있을 뿐입니다.

프로세스 ID에 의해 할당된 주 프로그램의 두 변수를 포함하는 파일을 고려하십시오. 하나는 현재 프로세스이고 다른 하나는 상위 프로세스입니다. 그런 다음 첫 번째 예와 유사하게 변수를 통해 두 ID를 모두 인쇄합니다.

Int pid_t = getpid();
Int ppid_t = getppid();

이 두 가지는 전체 코드의 주요 기능입니다. 이제 파일 생성 후 다음 단계는 파일을 컴파일하고 실행하는 것입니다. 명령에서 GCC를 사용하여 컴파일합니다. 컴파일 후 Ubuntu 터미널에서 실행합니다.

$ GCC –o code1 code1.c
$ ./코드1

출력은 프로세스 ID가 먼저 표시된 다음 상위 프로세스 ID가 표시됨을 보여줍니다.

실시예 3
모든 프로세스는 병렬 방식으로 실행 및 실행됩니다. 상위 및 하위 프로세스는 나머지 모든 라인을 집합적으로 실행합니다. 둘 다 한 번에 결과를 제공합니다. 그러나 C 코드에서 포크를 사용하여 이 함수가 0보다 작은 값을 반환하면 함수 호출이 종료되었음을 의미합니다.

각 헤더에 두 개의 라이브러리가 있는 새 파일을 고려하십시오. 여기서 if-else 문을 사용한 조건이 사용됩니다. 메인 프로그램에서는 fork 값이 -ive 값이면 프로세스의 id가 실패하여 얻을 수 없다는 메시지를 표시한다고 명시되어 있습니다. 상황이 거짓이면 컴파일러는 조건의 else 부분으로 이동합니다. 이 부분에서는 프로세스 ID를 얻은 다음 이 프로세스 ID를 표시하고 프로세스 ID를 얻었다는 메시지를 표시합니다. 여기서는 소스 코드의 if-else 문을 인용하겠습니다.

이제 다시 코드를 컴파일한 다음 실행합니다.

./코드2

출력은 else 부분이 실행되었음을 보여주고 프로세스 ID를 인쇄한 다음 PID 메시지를 표시합니다.

실시예 4

이것은 같은 개념을 설명하는 또 다른 예입니다. Fork() 함수는 두 개의 다른 값을 반환합니다. 자식 프로세스의 경우 값은 0으로 반환됩니다. 동시에 부모 프로세스의 경우 값은 새 자식의 프로세스 ID입니다.

이 예에서는 동일한 if_else 조건이 사용됩니다. 그러나 여기에는 두 가지 조건이 적용됩니다. 0보다 작은 PID와 다른 하나가 0인 PID를 비교합니다. PID가 0보다 작으면 오류 메시지가 표시됩니다. PID가 0이면 자식 프로세스임을 의미하고 else 부분은 PID가 0보다 크면 부모 프로세스임을 나타냅니다.

이제 코드를 컴파일하고 실행합니다.

$ gcc –o code3 code3.c
$./code3

출력에서 else 부분이 먼저 인쇄된다는 것은 프로세스 ID가 0보다 큼을 의미한다는 것을 알 수 있습니다.

실시예 5
좋습니다. 이것은 이 기능의 작동을 설명하기 위해 위에서 설명한 모든 코드를 요약한 마지막 예입니다. fork() 함수와 함께 루프를 사용하여 getpid() 함수를 사용할 수도 있습니다. 루프를 사용하여 많은 자식 프로세스를 만들 수 있습니다. 여기서 우리는 루프에서 3의 값을 사용해야 합니다.

다시 코드에서 조건문을 사용해야 합니다. for 루프는 1에서 시작하여 3까지 반복합니다.rd회전하다.

이제 파일을 저장하고 실행합니다. 단일 명령으로만 코드를 컴파일하고 실행하는 또 다른 간단한 방법이 있습니다. 그건.

$ GCC 코드5.c –o s & ./code5

이제 코드의 출력을 향해 이동합니다. 부모 프로세스의 id는 모든 자식 프로세스에서 동일합니다. 이것은 이러한 모든 프로세스가 하나의 부모에 속한다는 것을 의미합니다. 루프가 3으로 제한되어 있으므로 이러한 프로세스가 차례로 실행됩니다. 3번의 반복만 수행됩니다.

결론

이 기사는 기본 지식과 Linux 명령에서 getPID() 함수의 작동을 포함합니다. 이 기능을 통해 각 프로세스에 고유한 id를 할당합니다.