WinExec:两个参数,前一个指定路径,后一个指定显示方式。
ShellExecute:可以指定工作目录,并且还可以寻找文件的关联直接打开不用加载与文件关联的应用程序,ShellExecute还可以打开网页,启动相应的邮件关联发送邮件等等。
CreateProcess :一共有十个参数,不过大部分都可以用NULL代替,它可以指定进程的安全属性,继承信息,类的优先级等等。如果我们要得到足够多的关于新的进程的信息,控制新的进程的细节属性,若要达到这些目的,我们就需要使用CreateProcess函数了。
1. UINT WinExec(
LPCSTR lpCmdLine, // 命令路径
UINT uCmdShow // 显示方式
);
这个函数只能打开exe文件。
WinExec(_T("Notepad.exe"), SW_SHOW); // 打开记事本
WinExec(_T("D:\\Program Files\\Test\\Test.exe"),SW_SHOWMAXIMIZED); // 以最大化的方式打开Test.exe
2. HINSTANCE ShellExecute(
HWND hwnd, //父窗口句柄
LPCTSTR lpOperation, //操作, 打开方式 "edit","explore","open","find","print","NULL"
LPCTSTR lpFile, //文件名,前面可加路径
LPCTSTR lpParameters, //参数
LPCTSTR lpDirectory, //默认文件夹
INT nShowCmd //显示方式
);
这个函数可以打开任意文件,会调用系统注册的程序来打开对应后缀名的文件。
ShellExecute(NULL,_T("open"),_T("C:\\Test.txt"),NULL,NULL, SW_SHOWNORMAL); // 打开C:\Test.txt 文件
ShellExecute(NULL, _T("open"), _T("http://www.google.com/"), NULL, NULL, SW_SHOWNORMAL); // 打开网页www.google.com
ShellExecute(NULL,_T("explore"), _T("D:\\C++"),NULL,NULL,SW_SHOWNORMAL); // 打开目录D:\C++
ShellExecute(NULL,_T("print"),_T("C:\\Test.txt"),NULL,NULL , SW_HIDE); // 打印文件C:\Test.txt
3. BOOL CreateProcess(
LPCTSTR lpApplicationName, //执行程序名
LPTSTR lpCommandLine, // 参数行
//下面两个参数描述了所创建的进程和线程的安全属性,如果为NULL则使用默认的安全属性
LPSECURITY_ATTRIBUTES lpProcessAttributes, // process security attributes
LPSECURITY_ATTRIBUTES lpThreadAttributes, // thread security attributes
BOOL bInheritHandles, // 继承标志
DWORD dwCreationFlags, // 创建标志
LPVOID lpEnvironment, // 环境变量
LPCTSTR lpCurrentDirectory, // 运行该进程的初始目录
LPSTARTUPINFO lpStartupInfo, // 用于在创建子进程时设置各种属性
LPPROCESS_INFORMATION lpProcessInformation //用于在进程创建后接受相关信息
);
这个函数可以打开任意文件,会调用系统注册的程序来打开对应后缀名的文件。
参考:https://blog.csdn.net/samdy1990/article/details/16919969