进程入门之CreateProcess

本文参考: 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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值