在主进程中我监听SIGCHLD:
signal(SIGCHLD, &my_handler);
Then I fork()
, execv()
并让它在后台运行(例如/bin/cat)。
当我尝试从终端向子进程发送 SIGSTOP 时,my_handler()
被叫。但是当我尝试向它发送 SIGCONT 时,处理程序不会在 macOS 上调用,而是在我的 Ubuntu 上执行。
Man:
SIGCHLD:子状态已更改。
我错过了什么吗?这是预期的行为吗?我在 Ubuntu 上编写了我的应用程序,并希望它也能在 Mac 上运行。
我尝试过sigaction()
也是如此,但结果相同。
这是一个示例代码来演示:
#include <signal.h>
#include <sys/wait.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <unistd.h>
void my_handler(int signum)
{
printf("\t SIGCHLD received\n");
fflush(stdout);
}
void my_kill(pid_t pid, int signum)
{
printf("Sending %d\n", signum);
fflush(stdout);
kill(pid, signum);
printf("Sent %d\n\n", signum);
fflush(stdout);
}
int main()
{
pid_t pid;
char *cat_args[2] = {"/bin/cat", NULL};
signal(SIGCHLD, &my_handler);
pid = fork();
if (pid == 0)
{
execv("/bin/cat", cat_args);
}
else
{
my_kill(pid, SIGSTOP);
my_kill(pid, SIGCONT);
wait(NULL);
}
return 0;
}
macOS 上的输出:
Sending 17
SIGCHLD received
Sent 17
Sending 19
Sent 19