我正在使用 fork 在 Mac 平台上创建一个进程,并等待子进程在父进程中完成。但是 waitpid
返回 -1 并且 errno 为 4 (EINTR)。
可以重现该问题的示例代码如下:
#include <iostream>
#include <sys/types.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <assert.h>
int main(int argc, const char *argv[])
{
pid_t pid = ::fork();
if (pid == 0)
{
return 0;
}
int s = 0;
if (::waitpid(pid, &s, 0) == -1)
{
printf("The errno is :%d\n", errno); // <<<The errno is 4(EINTR) in my machine.
assert(false); // <<<<This will be hit if run in debugger.
}
return 0;
}
当我在 GDB
或 LLDB
中运行此代码时,assert
将始终被命中。如果不在调试器中运行,它不会返回 -1。
我认为对于 debugger
或 fork/waitpid
的工作原理,我有一些不明白的地方。那么谁能解释为什么会这样?
最佳答案
调试器正在向进程发送信号。正如 WhozCraig 所说,这些应该通过检测 EINTR 并在循环中再次调用 waitpid 来处理。请注意,在调试器中运行 child 进程时,调试器可能会将父进程更改为调试器的 PID,因此子 PID 上的 waitpid 将失败,认为子进程已经退出,即使它已经退出不是。当调试器退出时,它将子进程的 PPID 恢复为原始父进程的 PID。
关于c - 为什么 waitpid 在调试器中运行时返回 -1?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21554195/