我编写了一个多平台c++类,它启动用户指定的子进程,并允许用户与子进程的stdin/stdout通信,等待子进程退出,等等。
在这个类的Unix/POSIX实现中,我刚刚添加了一个功能,可以让调用者发现子进程的退出是否由于未处理的信号(即崩溃):
bool ChildProcessDataIO :: WaitForChildProcessToExit(bool & retDidChildProcessCrash)
{
int status = 0;
int pid = waitpid(_childPID, &status, 0);
if (pid == _childPID)
{
retDidChildProcessCrash = WIFSIGNALED(status);
return true;
}
else return false; // error, couldn't get child process's status
}
…现在我想在Windows实现中添加类似的功能,目前看起来像这样:
bool ChildProcessDataIO :: WaitForChildProcessToExit(bool & retDidChildProcessCrash)
{
bool ret = (WaitForSingleObject(_childProcess, INFINITE) == WAIT_OBJECT_0);
if (ret)
{
/* TODO: somehow set (retDidChildProcessCrash) here */
}
return ret;
}
…但我还没有弄清楚如何设置(retDidChildProcessCrash)使用Win32 API的适当值。
是否有办法做到这一点,或者我只需要在我的文档中注明此功能目前未在Windows下实现?
安排孩子与父母沟通以表示完成。共享事件是一种方式。如果进程终止,父进程没有收到成功的通知,那么它可以得出子进程失败的结论。
另一个选项可能是使用进程退出代码。如果孩子遵循常规,那么成功的概率为零。而崩溃将导致一个错误代码,表明崩溃的形式,根据这个问题:Windows中崩溃进程的可预测退出代码?
这是不太可靠的。进程可能因为调用了TerminateProcess
而终止,退出代码为0。所以如果你控制了两个过程,第一种方法更安全。如果您不控制子进程,那么退出代码可能是您最好的选择。从已终止进程的进程句柄中,您无法获得更多信息。