启动、关闭外部进程ShellExecute() 、CreateProcess()、TerminateProcess()、OpenProcess()==
2016-05-02 22:52
399 查看
学习用到了启动、关闭外部进程的知识,通过网上资料及自身实践作如下总结:
主要用到:ShellExecute() 、CreateProcess()、TerminateProcess()、OpenProcess()==
1.ShellExecute(
hWnd: HWND; {指定父窗口句柄}
Operation: PChar; {指定动作, 譬如: open、runas、print、edit、explore }
FileName: PChar; {指定要打开的文件或程序}
Parameters: PChar; {给要打开的程序指定参数; 如果打开的是文件这里应该是 nil}
Directory: PChar; {缺省目录}
ShowCmd: Integer {指定程序窗口的初始显示方式(SW_SHOW、SW_HIDE==)}
)
执行成功会返回应用程序句柄HINSTANCE类型(返回的值为整数,只是转换为 HINSTANCE 并不是真正的
HINSTANCE ,唯一的作用是重新转换为整数判断操作是否成功)
返回的HINSTANCE可以将它转换为一个整数(%d),并比较它的值大于还是小于32或比较它的错误代码
返回值大于32表示执行成功
返回值小于=32表示执行错误
2.ShellExecuteEx().............
3.CreateProcess(
LPCTSTR lpApplicationName,//指向一个NULL结尾的、用来指定可执行模块的字符串
LPTSTR lpCommandLine,//指向一个以NULL结尾的字符串,该字符串指定要执行的命令行
LPSECURITY_ATTRIBUTES lpProcessAttributes,
LPSECURITY_ATTRIBUTES lpThreadAttributes,
BOOL bInheritHandles,
DWORD dwCreationFlags,
LPVOID lpEnvironment,
LPCTSTR lpCurrentDirectory,
LPSTARTUPINFO lpStartupInfo,//指向一个用于决定新进程的主窗体如何显示的STARTUPINFO结构体
LPPROCESS_INFORMATION lpProcessInformation
//指向一个用来接收新进程的识别信息的PROCESS_INFORMATION结构体
)
成功返回非0,失败返回0
1.如果lpApplicationName和lpCommandLine参数都不为空,那么lpApplicationName参数指定将要被运行的模块,lpCommandLine参数指定将被运行的模块的命令行。参数传入int main(int
argc,char* argv[])中,argc=1,argv[0]=lpCommandLine的内容。
新运行的进程可以使用GetCommandLine函数获得整个命令行(只获取lpCommandLine的内容,不包括lpApplicationName的内容)。
2.若lpApplicationName为NULL,在这种情况下,可执行模块的名字必须处于
lpCommandLine 参数最前面并由空格符与后面的字符分开。
4.根据进程名称获取p_id
5.OpenProcess(
DWORD dwDesiredAccess, //渴望得到的访问权限(标志)
BOOL bInheritHandle, // 是否继承句柄
DWORD dwProcessId// 进程标示符p_id
)//用来打开一个已存在的进程对象,并返回进程的句柄
6.BOOL
TerminateProcess(
HANDLE hProcess,//进程句柄
UINT uExitCode //进程终止码
)//终止指定进程及其所有线程
主要用到:ShellExecute() 、CreateProcess()、TerminateProcess()、OpenProcess()==
1.ShellExecute(
hWnd: HWND; {指定父窗口句柄}
Operation: PChar; {指定动作, 譬如: open、runas、print、edit、explore }
FileName: PChar; {指定要打开的文件或程序}
Parameters: PChar; {给要打开的程序指定参数; 如果打开的是文件这里应该是 nil}
Directory: PChar; {缺省目录}
ShowCmd: Integer {指定程序窗口的初始显示方式(SW_SHOW、SW_HIDE==)}
)
执行成功会返回应用程序句柄HINSTANCE类型(返回的值为整数,只是转换为 HINSTANCE 并不是真正的
HINSTANCE ,唯一的作用是重新转换为整数判断操作是否成功)
返回的HINSTANCE可以将它转换为一个整数(%d),并比较它的值大于还是小于32或比较它的错误代码
返回值大于32表示执行成功
返回值小于=32表示执行错误
2.ShellExecuteEx().............
3.CreateProcess(
LPCTSTR lpApplicationName,//指向一个NULL结尾的、用来指定可执行模块的字符串
LPTSTR lpCommandLine,//指向一个以NULL结尾的字符串,该字符串指定要执行的命令行
LPSECURITY_ATTRIBUTES lpProcessAttributes,
LPSECURITY_ATTRIBUTES lpThreadAttributes,
BOOL bInheritHandles,
DWORD dwCreationFlags,
LPVOID lpEnvironment,
LPCTSTR lpCurrentDirectory,
LPSTARTUPINFO lpStartupInfo,//指向一个用于决定新进程的主窗体如何显示的STARTUPINFO结构体
LPPROCESS_INFORMATION lpProcessInformation
//指向一个用来接收新进程的识别信息的PROCESS_INFORMATION结构体
)
成功返回非0,失败返回0
1.如果lpApplicationName和lpCommandLine参数都不为空,那么lpApplicationName参数指定将要被运行的模块,lpCommandLine参数指定将被运行的模块的命令行。参数传入int main(int
argc,char* argv[])中,argc=1,argv[0]=lpCommandLine的内容。
新运行的进程可以使用GetCommandLine函数获得整个命令行(只获取lpCommandLine的内容,不包括lpApplicationName的内容)。
2.若lpApplicationName为NULL,在这种情况下,可执行模块的名字必须处于
lpCommandLine 参数最前面并由空格符与后面的字符分开。
CString commandline=(CString)proname+" "+(CString)addr; BOOL cp=CreateProcess(NULL,(LPSTR)(char*)commandline.GetBuffer(),NULL,NULL,FALSE,0,NULL,NULL,&s_info,&p_info);此时,argc=2,argv[0]=外部可执行程序的名字,argv[1]=参数部分。
4.根据进程名称获取p_id
5.OpenProcess(
DWORD dwDesiredAccess, //渴望得到的访问权限(标志)
BOOL bInheritHandle, // 是否继承句柄
DWORD dwProcessId// 进程标示符p_id
)//用来打开一个已存在的进程对象,并返回进程的句柄
6.BOOL
TerminateProcess(
HANDLE hProcess,//进程句柄
UINT uExitCode //进程终止码
)//终止指定进程及其所有线程
相关文章推荐
- 用shell脚本模拟用户按键、触摸操作
- centos 下用shell脚本启动jar包
- shell中循环监控MQ当前深度
- shell脚本:cp某个目录下筛选(find)后的某些文件到另一个目录
- ansible之shell和script模块
- Xshell4连接,Linux系统中文显示乱码解决办法
- Powershell集成OPENSSL客户端
- Linux入门基础 #1:命令行bash基本操作
- Linux shell 命令行参数
- shell简单使用(二)循环
- linux shell学习笔记二---自定义函数(定义、返回值、变量作用域)介绍
- linux shell脚本学习笔记一
- 05- Shell脚本学习--函数
- pgsql自动安装shell脚本整理
- shell面试题
- 常用的shell命令(持续更新)
- linux shell命令行选项与参数用法详解
- 希尔排序(Shell)
- Shell脚本中单引号(‘)和双引号(“)的使用区别[转载]
- bash环境变量读取顺序