本文主要介绍两种在windows下调用外部exe程序的方法:
1、使用SHELLEXECUTEINFO 和ShellExecuteEx
SHELLEXECUTEINFO 结构体的定义如下:
lpVerb
指定执行的动作,包括:edit,explore,find,open,print,properties
lpFile
以结尾的字符串,指出lpVerb的操作对象的路径,被系统支持的操作包括文本的open、print等
lpParameters
可选。运行/打开程序的参数,如果打开的是一个文档,则该项无效
lpDirectory
可选。指明工作目录的名字,成员没有说明,则默认为当前目录
nShow
必须。指定打开的程序的显示方式,为SW_值中的一个。
hInstApp
【out】如果设置SEE_MASK_NOCLOSEPROCESS S值并且ShellExecuteEx调用成功,则该项的值大于32,如果调用失败,则将设置为SE_ERR_XXX的错误值。
lpIDList
一个ITEMIDLIST结构的地址,用来存储成员的特别标识符,当fMask不包括SEE_MASK_IDLIST或SEE_MASK_INVOKEIDLIST时该项被忽略
lpClass
用以指明文件类别的名字或GUID,当fMask不包括SEE_MASK_CLASSNAME时该项被忽略
hkeyClass
获得已在系统注册的文件类型的Handle,当fMask不包括SEE_MASK_HOTKEY时该项被忽略
dwHotKey
程序的热键关联,低位存储虚拟关键码(Key Code),高位存储修改标志位(HOTKEYF_),修改标志为(modifier flags)的详细列表请看WM_SETHOTKEY消息的描述,当fmask不包括SEE_MASK_HOTKEY时该项被忽略
DUMMYUNIONNAME
hIcon
取得对应文件类型的图标的Handle,当fMask不包括SEE_MASK_ICON时该项被忽略
hMonitor
将文档显示在显示器上的Handle,当fMask不包括SEE_MASK_HMONITOR时该项被忽略
hProcess
指向新启动的程序的句柄。若fMask不设为SEE_MASK_NOCLOSEPROCESS则该项值为NULL。但若程序没有启动,即使fMask设为SEE_MASK_NOCLOSEPROCESS,该值也仍为NULL。
ShellExecuteEx功能:Performs an operation on a specified file。对指定应用程序执行某个操作
原型:
BOOLShellExecuteEx(LPSHELLEXECUTEINFOlpExecInfo);
参数:
lpExecInfo
[in, out]一个指向SHELLEXECUTEINFO结构的指针,用来传递和保存应用程序执行相关的信息。
返回值:
如果函数成功执行就返回TRUE,否则返回FALSE。可调用GetLastError获取错误信息。
备注:
由于ShellExecuteEx能够将执行委托给那些由组件对象模型COM激活的Shell扩展(数据源,上下文菜单句柄,动词实现),因此在调用ShellExecuteEx之前要先初始化COM。某些Shell扩展要求单线程单元模型的COM,在这种情况下,应当像下面一般初始化COM:
CoInitializeEx (NULL,COINIT_APARTMENTTHREADED | COINIT_DISABLE_OLE1DDE)
在某些情况下ShellExecuteEx并没有使用这种类型的Shell扩展,这时就无需初始化COM。虽然如此,总是在使用这个函数之前初始化COM是个不错的举措。
使用实例:
11 CPLString kduParameters = CPLSPrintf("-i %s -o %s",name.c_str(),pgmname.c_str());12 shellInfo.lpParameters = (LPCSTR)(kduParameters.c_str());14 bool isOver = ShellExecuteEx( shellInfo);15 WaitForSingleObject(shellInfo.hProcess,INFINITE);