반응형
- 본 내용은 Linux (Ubuntu 14.04 lts)를 기반으로 제작되었습니다. -
계속해서 fork, wait, kill같은 함수들을 알아보는 이유는,
결국 소켓 프로그래밍의 마지막은 다중 사용자에게 대해 서버가 처리해 줄것들을 프로그래밍 하기위함이다.
이번에는 kill 함수에 대해 알아본다.
kill 함수의 원형은 다음과 같다.
int kill(pid_t pid, int signal);
0을 리턴하면 성공, 실패하면 -1을 리턴한다.
pid는 말 그대로 프로세스 id를 적는 부분이고,
signal은 http://www.crocus.co.kr/245 를 참조하여 확인할 수 있다.
아래 소스 코드의 동작 과정은 다음과 같다.
처음에 부모 프로세스가 자식 프로세스를 50번 fork()한다.
이때 50번 하는 동안 부모 프로세스에게 할당된 시간이 timeout이 되거나, 다른 인터럽트에 의해 부모 프로세스가
swap되고, 자식 프로세스의 차례가 오면 자식 프로세스는 pid가 0이기에 while문을 돌게된다.
그 후, 시간이 지나 부모 프로세스차례가 와서 50번의 fork()를 끝낸 후 두번째 for문에서 자식 프로세스를
하나씩 죽이는 과정을 취한다. 자식 프로세스가 다 죽으면 마지막에 부모 프로세스가 종료된다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | #include <sys/types.h> #include <sys/wait.h> #include <stdio.h> #include <signal.h> int main() { int N = 50; pid_t pid[N]; /* process id */ int childStatus; int i; for (i = 0; i < N; i++) { pid[i] = fork(); if (pid[i] == 0) { while(1) printf("Child Process :: %d is never terminate\n",getpid()); } } for (i = 0; i < N; i++) { printf("Killing Child Process :: %d\n",pid[i]); kill(pid[i],SIGINT); // The Parent Process kills the child process by sending a SIGINT signal } printf("Now Parent Process is terminate\n"); return 0; } // This source code Copyright belongs to Crocus // If you want to see more? click here >> | Crocus |
다음은 실제 실행 과정을 동영상으로 담아두었다.
아래 동영상이 화질이 좋지 않다면 다음 주소를 이용하길 바란다.
반응형
'Applied > Network' 카테고리의 다른 글
소켓 프로그래밍 - (11) SIGALRM 사용 방법 (1) | 2016.10.15 |
---|---|
소켓 프로그래밍 - (10) signal함수 사용 방법 (0) | 2016.10.15 |
소켓 프로그래밍 - (8) 다중 fork() 사용과 이해 (0) | 2016.10.10 |
소켓 프로그래밍 - (7) fork() 함수 기초 (0) | 2016.10.09 |
소켓 프로그래밍 - (6) UDP 소켓 통신 응용(닉네임, 최대 인원, 메시지 응용) (2) | 2016.10.06 |