【vs2015】C++ 程序运行并等待进程结束


1.VS2015 新建项目->win32 控制台应用程序

以下操作实现跨平台
(1).配置属性-常规-MFC的使用->使用标准Windows库或者在静态库中使用MFC
(2).配置属性-c/c++-代码生成-运行库->多线程(/MT)

2.头文件stdafx.h

// stdafx.h : 标准系统包含文件的包含文件,
// 或是经常使用但不常更改的
// 特定于项目的包含文件
//

#pragma once
//#define _AFXDLL
#include "targetver.h"

#include <stdio.h>
#include <tchar.h>


// TODO:  在此处引用程序需要的其他头文件

#include <afxwin.h>         // MFC core and standard components
#include <SetupAPI.h>
#pragma comment(lib, "Setupapi.lib")


3.主程序ConsoleApplication5.cpp

// ConsoleApplication1.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
int main()
{
	LPTSTR buffer = _T("demo1,demo2,demo3");
	printf("dev_ID=%S \n", buffer);
	if (buffer)
	{
		
		LPTSTR demo = _T("demo2");		


		if (_tcsstr(buffer, demo))
		{
			printf("Detect demo2  !!!!!!\n");

			STARTUPINFO si;
			PROCESS_INFORMATION pi;
			ZeroMemory(&si, sizeof(si));
			si.cb = sizeof(si);
			ZeroMemory(&pi, sizeof(pi));
			LPTSTR szCmdline = _tcsdup(TEXT("Driver\\demo\\Setup.exe"));
			// Start the child process. 
			if (!CreateProcess(NULL,   // No module name (use command line)
				szCmdline,        // 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 0;*/
				exit(0);
			}

			// Wait until child process exits.
			WaitForSingleObject(pi.hProcess, INFINITE);

			// Close process and thread handles. 
			CloseHandle(pi.hProcess);
			CloseHandle(pi.hThread);

			printf(" demo Install Finished  !!!!!!\n");

		}
		/*-------------demo end-----------------*/
	}	
	return 0;
}

4.效果


  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++ 中运行外部程序可以使用 `system` 或者 `CreateProcess` 函数。如果要隐藏命令框,可以使用 `CreateProcess` 函数并设置 `STARTUPINFO` 结构体中的 `wShowWindow` 字段为 `SW_HIDE`。示例如下: ```c++ #include <windows.h> #include <stdio.h> int main() { STARTUPINFO si; PROCESS_INFORMATION pi; ZeroMemory(&si, sizeof(si)); si.cb = sizeof(si); ZeroMemory(&pi, sizeof(pi)); // 设置 STARTUPINFO 结构体 si.dwFlags = STARTF_USESHOWWINDOW; si.wShowWindow = SW_HIDE; // 启动外部程序 if (!CreateProcess(NULL, "notepad.exe", NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) { printf("CreateProcess failed (%d).\n", GetLastError()); return 1; } // 等待外部程序结束 WaitForSingleObject(pi.hProcess, INFINITE); // 关闭句柄 CloseHandle(pi.hProcess); CloseHandle(pi.hThread); return 0; } ``` 如果父进程结束启动的外部程序不结束,可能是因为父进程没有等待进程结束。可以使用 `WaitForSingleObject` 或者 `WaitForMultipleObjects` 函数等待进程结束。示例如下: ```c++ #include <windows.h> #include <stdio.h> int main() { STARTUPINFO si; PROCESS_INFORMATION pi; ZeroMemory(&si, sizeof(si)); si.cb = sizeof(si); ZeroMemory(&pi, sizeof(pi)); // 设置 STARTUPINFO 结构体 si.dwFlags = STARTF_USESHOWWINDOW; si.wShowWindow = SW_HIDE; // 启动外部程序 if (!CreateProcess(NULL, "notepad.exe", NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi)) { printf("CreateProcess failed (%d).\n", GetLastError()); return 1; } // 等待外部程序结束 WaitForSingleObject(pi.hProcess, INFINITE); // 关闭句柄 CloseHandle(pi.hProcess); CloseHandle(pi.hThread); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值