本文参考: http://blog.csdn.net/hityct1/article/details/3968296
先看一代码,使用CreateProcess 创建进程,是在win32 的控制台下运行。
// sample.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <windows.h>
#include <stdio.h>
// 创建一个新进程
// 使用ie打开指定的网页-百度
int _tmain(int argc, _TCHAR* argv[])
{
STARTUPINFO si = { sizeof(si) };
PROCESS_INFORMATION pi;
si.dwFlags = STARTF_USESHOWWINDOW;
si.wShowWindow = TRUE; //TRUE表示显示创建的进程的窗口
TCHAR cmdline[] =TEXT("c://program files//internet explorer//iexplore.exe http://www.baidu.com/");
BOOL bRet = ::CreateProcess (
NULL,
cmdline, //在Unicode版本中此参数不能为常量字符串,因为此参数会被修改
NULL,
NULL,
FALSE,
CREATE_NEW_CONSOLE,
NULL,
NULL,
&si,
&pi);
int error = GetLastError();
if(bRet)
{
::CloseHandle (pi.hThread);
::CloseHandle (pi.hProcess);
printf(" 新进程的进程ID号:%d \n", pi.dwProcessId);
printf(" 新进程的主线程ID号:%d \n", pi.dwThreadId);
}
else
{
printf("error code:%d/n",error );
}
return 0;
}
解释:BOOL CreateProcess(
LPCTSTR lpApplicationName, // 这个表示 指向可执行文件名字的字符串。如 "c://program files//internet explorer//iexplore.exe"
LPTSTR lpCommandLine,
//如果第一个参数为NULL,那么这里也可以表示 指向可执行文件名字的字符串。如上面sample所示。其实这里也可以为第一个参数传递命令行 参 数LPSECURITY_ATTRIBUTES lpProcessAttributes, //不重要
LPSECURITY_ATTRIBUTES lpThreadAttributes, //不重要
BOOL bInheritHandles, // 一般为 false
DWORD dwCreationFlags, //较为复杂
LPVOID lpEnvironment, //一般为NULL
LPCTSTR lpCurrentDirectory, //这个字符串用来指定子进程的工作路径。这个字符串必须是一个包含驱动器名的绝对路径。可以为空。
LPSTARTUPINFO lpStartupInfo, //决定新进程的主窗体如何显示
LPPROCESS_INFORMATION lpProcessInformation //接收新进程的识别信息,这里存放新进程的一些信息);
}
参考:http://baike.baidu.com/link?url=3wbV6Gh_xH1OnLs1w4flVp2ZL8cltS1DSyvgKhQa8AwnFiE5BtkRuthrVBqy66Ed