首页 > 解决方案 > C 中的 CreateProcessA、Wait 和 ExitCode - 获取错误的退出代码

问题描述

我在 C 中使用 CreateProcessA 和 Wait(...) 函数的代码存在问题。一切似乎都很好,除了退出代码。它始终为 0。我知道(至少)这部分代码(带有退出代码)是错误的,但我尝试了很多方法来修复它,但没有一个真正起作用。此外,在控制台中显示 PID 时,它们有时不在应有的位置(例如:有 3 行具有相同的 PID,有时还有一个来自其他组的额外 PID,例如:6656 6656 1234 6656 ...)。也许你们知道解决方案。这是代码:

    ...//some argument conditions above
    STARTUPINFO si;
    PROCESS_INFORMATION pi[2];

    memset(&si, 0, sizeof(si));
    memset(&pi, 0, sizeof(pi));
    si.cb = sizeof(si);

    int argument = atoi(argv[1]);   
    int argument1 = argument - 1;
    int argument2 = argument - 2;

    char a1[50];
    sprintf(a1, "file.exe %d", argument1);

    BOOL v1 = CreateProcessA("file.exe", a1, NULL, NULL, FALSE, 0, NULL, NULL, &si, pi+0);


    char a2[50];
    sprintf(a2, "file.exe %d", argument2);

    BOOL v2 = CreateProcessA("file.exe", a2, NULL, NULL, FALSE, 0, NULL, NULL, &si, pi+1);


    
    HANDLE children[2] = { pi[0].hProcess, pi[1].hProcess };
    WaitForMultipleObjects(2, children, 1, INFINITE);
    for (int i = 1; i >= 0; i--)
    {       
        CloseHandle(pi[i].hProcess);
        CloseHandle(pi[i].hThread);
    }

    unsigned long int exit1 = GetExitCodeProcess(children[0], &exit1);
    unsigned long int exit2 = GetExitCodeProcess(children[1], &exit2);
    
    printf("%d \t %d \t %d \t %d \t\n", GetCurrentProcessId(), pi[0].dwProcessId, argument1, exit1);

    
    printf("%d \t %d \t %d \t %d \t\n", GetCurrentProcessId(), pi[1].dwProcessId, argument2, exit2);

    printf("%d \t \t \t %d\n\n", GetCurrentProcessId(), exit1 + exit2);


    return exit1 + exit2;
}

谢谢你的帮助。

标签: cprocessoperating-systemwaitcreateprocess

解决方案


在这段代码中:

    HANDLE children[2] = { pi[0].hProcess, pi[1].hProcess };
    WaitForMultipleObjects(2, children, 1, INFINITE);
    for (int i = 1; i >= 0; i--)
    {       
        CloseHandle(pi[i].hProcess);
        CloseHandle(pi[i].hThread);
    }

    unsigned long int exit1 = GetExitCodeProcess(children[0], &exit1);
    unsigned long int exit2 = GetExitCodeProcess(children[1], &exit2);

一个问题是exit1exit2被初始化为 的返回值GetExitCodeProcess。该函数的返回类型为BOOL并且在失败时返回 0 ( FALSE),或者在成功时返回非零值(可能是 1 ( TRUE))。由于进程句柄已经在前面的for循环中关闭,GetExitCodeProcess将返回失败值 0。

尝试将其更改为以下内容:

    HANDLE children[2] = { pi[0].hProcess, pi[1].hProcess };
    WaitForMultipleObjects(2, children, 1, INFINITE);
    DWORD exit1, exit2;
    GetExitCodeProcess(children[0], &exit1);
    GetExitCodeProcess(children[1], &exit2);
    for (int i = 1; i >= 0; i--)
    {       
        CloseHandle(pi[i].hProcess);
        CloseHandle(pi[i].hThread);
    }

推荐阅读