之前有一个疑问,就是在使用fork的多进程的程序中,如果其前台,并通过ctrl-c企图终止该进程,那么父进程与子进程是否都会捕获到信号,于是做了一个小测试,代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
void signal_handle(int sig)
{
pid_t pid = getpid();
fprintf(stdout, "signal_handle pid = %d\n", pid);
}
int main(int argc, char *argv[])
{
pid_t childpid;
if (signal(SIGINT, signal_handle) == SIG_ERR)
perror("signal");
childpid = fork();
switch (childpid)
{
case -1:
{
perror("fork");
return -1;
}
case 0:
{
while (1);
}
default:
{
while (1);
}
}
return 0;
}
运行代码,并多次使用ctrl-c向进程发送SIGINT信号,得到的结果如下:
signal_handle pid = 4884
signal_handle pid = 4887
signal_handle pid = 4887
signal_handle pid = 4884
signal_handle pid = 4887
signal_handle pid = 4884
signal_handle pid = 4887
signal_handle pid = 4884
signal_handle pid = 4887
signal_handle pid = 4884
signal_handle pid = 4887
signal_handle pid = 4884
可以看到,父进程为4884,子进程为4887,并且两个进程都收到了该信号。