This question already has answers here:
Why those two different behaviors with WaitForSingleObject function in CPP
(2个答案)
2年前关闭。
我想等待进程执行结束(calc.exe),但是它不起作用。
我的程序快速完成/现在完成,而我的进程(calc.exe)继续运行(我没有停止它)。
WaitForSingleObject立即返回WAIT_OBJECT_0。
ps:我禁用了软件防病毒(AVIRA)
(2个答案)
2年前关闭。
我想等待进程执行结束(calc.exe),但是它不起作用。
我的程序快速完成/现在完成,而我的进程(calc.exe)继续运行(我没有停止它)。
WaitForSingleObject立即返回WAIT_OBJECT_0。
ps:我禁用了软件防病毒(AVIRA)
int main(int argc, char** arv)
{
STARTUPINFO si;
PROCESS_INFORMATION pi;
ZeroMemory(&si, sizeof(si));
si.cb = sizeof(si);
ZeroMemory(&pi, sizeof(pi));
const char * calcPrgm = "C:\\\\Windows\\System32\\calc.exe";
LPSTR calcPrgmLpstr = const_cast<LPSTR>(calcPrgm);
// Start the child process.
if (!CreateProcess(NULL, // No module name (use command line)
calcPrgmLpstr, // Command line
NULL, // Process handle not inheritable
NULL, // Thread handle not inheritable
FALSE, // Set handle inheritance to FALSE
0, // No creation flags
NULL, // Use parent's environment block
NULL, // Use parent's starting directory
&si, // Pointer to STARTUPINFO structure
&pi) // Pointer to PROCESS_INFORMATION structure
)
{
printf("CreateProcess failed (%d).\n", GetLastError());
return -1;
}
// Wait until child process exits.
auto ret = WaitForSingleObject(pi.hProcess, INFINITE);
printf("WaitForSingleObject ret = %x\n", ret);
if (ret == WAIT_OBJECT_0)
{
printf("WaitForSingleObject ret ret == WAIT_OBJECT_0\n");
}
BOOL b = FALSE;
DWORD n = 0;
b = GetExitCodeProcess(pi.hProcess, &n);
// Close process and thread handles.
CloseHandle(pi.hProcess);
CloseHandle(pi.hThread);
printf("WaitForSingleObject end\n");
return 0;
}
最佳答案
我发现了错误。 “ calc.exe”在退出之前创建另一个进程。我使用“ Sleep(60 * 1000);”主代码中的1行代码创建/调用了自己的程序。没关系:)
关于c++ - WaitForSingleObject不等待过程结束,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/51674939/
10-16 17:54