3

我正在使用 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否则LLDBassert始终被击中。如果不在调试器中运行,它将不会返回 -1。

debugger我认为我对如何或如何工作有一些不明白的地方fork/waitpid。那么任何人都可以解释为什么会发生这种情况吗?

4

1 回答 1

3

调试器正在向进程发送信号。正如 WhozCraig 所说,这些应该通过检测 EINTR 并在循环中再次调用 waitpid 来处理。请注意,在调试器中运行进程时,调试器可能会将父进程更改为调试器的 PID,因此子 PID 上的 waitpid 将失败,认为子进程已退出,即使它没有退出。当调试器退出时,它将子进程的 PPID 恢复为原始父进程的 PID。

于 2017-08-03T00:21:25.577 回答