[英]Signals Behavior in C/C++ - Linux
对流程和信号完全陌生,我正在搞乱我编写的以下代码:
void childSignalHandler(int signalCode) {
if (signalCode == SIGUSR1)
cout << "Child here : Received ping, responding" << endl;
}
void parentSignalHandler(int signalCode) {
if (signalCode == SIGINT)
cout << "Parent here : Pinging Child" << endl;
else if (signalCode == SIGUSR1)
cout << "Parent here : Received response" << endl;
}
int main() {
int pid = fork();
/* Child process*/
if (pid == 0) {
if (signal(SIGUSR1, childSignalHandler) == SIG_ERR) {
perror("Child SIGUSR1");
exit(1);
}
// This did the trick!
if (signal(SIGINT,SIG_IGN) == SIG_ERR){
perror("Child SIGINT");
exit(1);
}
pause();
kill(getppid(), SIGUSR1);
} else {
if (signal(SIGINT, parentSignalHandler) == SIG_ERR) {
perror("Parent SIGINT");
exit(1);
}
if (signal(SIGUSR1, parentSignalHandler) == SIG_ERR) {
perror("Parent SIGUSR1");
exit(1);
}
raise(SIGINT); // Maybe change it to pause(); to use keyboard instead ?
kill(pid, SIGUSR1);
pause();
}
return 0;
}
上面的代码工作得很好,预期的行为是:
Parent here : Pinging Child
Child here : Received ping, responding
Parent here : Received response
但是,当我使用键盘Ctrl + C
信号尝试相同的操作并更改raise(SIGINT);
pause();
那么 output 是:
^CParent here : Pinging Child
^CParent here : Pinging Child
我认为这会起作用的方式是:
CTRL + C
又名SIGINT
将被发送到将被取消暂停的父进程parentSignalHandler()
将处理SIGINT
并打印相应的消息SIGUSR1
,该子进程将被取消暂停,父进程本身将再次暂停childSignalHandler()
将处理SIGUSR1
SIGUSR1
给父进程,父进程将再次由parentSignalHandler()
处理看起来它不像我想象的那样工作,任何洞察力都会非常有帮助。
编辑——更新代码
raise(SIGINT)
仅将SIGINT
信号发送到调用进程——在这种情况下是父进程。 另一方面,当您使用CTRL + C
发送SIGINT
信号时,您会将其发送到所有前台进程,即子进程也收到它并因此终止。 所以不再有子进程来回复父进程的SIGUSR1
信号。 尝试忽略子进程中的信号。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.