2

我想通过CreateProcess以下步骤使用函数从主应用程序启动子应用程序:

  1. .exe从没有子程序窗口的主程序启动子程序
  2. 等待rand Sleep
  3. 然后先终止子应用程序,然后终止主应用程序。

在下面我的示例代码中,但子程序与窗口一起运行(在本例中为记事本),我无法终止子程序。

#include "stdafx.h"
#include <windows.h>
#include <conio.h>
#include <strsafe.h>
#include <direct.h>
#include <string.h>

int main(int argc, char* argv[])
{   

HWND                hWnd;
STARTUPINFO         sInfo;
PROCESS_INFORMATION pInfo;

ZeroMemory(&sInfo, sizeof(sInfo));
sInfo.cb = sizeof(sInfo);
ZeroMemory(&pInfo, sizeof(pInfo));

if (CreateProcess("C:\\WINDOWS\\System32\\notepad.exe", NULL, NULL, NULL, false, CREATE_NO_WINDOW, NULL, NULL, &sInfo, &pInfo))
{
    printf("Sleeping 100ms...\n");
    Sleep(100);

    DWORD dwExitCode;
    GetExitCodeProcess(pInfo.hProcess, &dwExitCode);

    CloseHandle(pInfo.hThread);
    CloseHandle(pInfo.hProcess);

    }

system("pause");

return 0;

 }
4

1 回答 1

2

记事本窗口显示的原因是它不是控制台应用程序。MSDN这样说CREATE_NO_WINDOW

该进程是一个在没有控制台窗口的情况下运行的控制台应用程序。因此,未设置应用程序的控制台句柄。 如果应用程序不是控制台应用程序,或者与 CREATE_NEW_CONSOLE 或 DETACHED_PROCESS 一起使用,则忽略此标志。

相反,使用STARTUPINFO你传入的:

sInfo.dwFlags = STARTF_USESHOWWINDOW;
sInfo.wShowWindow = SW_HIDE;

我相信这会影响WinMain记事本 main 函数中的最后一个参数,但我不确定。

至于为什么记事本不关闭,GetExitCodeProcess实际上并没有结束进程,它只是检索状态。您可以TerminateProcess改用:

TerminateProcess(pInfo.hProcess, 0);
于 2013-01-13T09:40:44.680 回答