CreatePipe函数用于创建一个匿名管道,CreateProcess函数用于创建一个新的进程。下面是它们的使用方法:
【CreatePipe函数】
BOOL CreatePipe(
PHANDLE hReadPipe,
PHANDLE hWritePipe,
LPSECURITY_ATTRIBUTES lpPipeAttributes,
DWORD nSize
);
hReadPipe和hWritePipe:接收创建的匿名管道的句柄,一个用于读取数据,一个用于写入数据。
lpPipeAttributes:指向SECURITY_ATTRIBUTES结构的指针,用于指定管道的安全属性。如果为NULL,则默认为不继承句柄。
nSize:指定管道的缓冲区大小,如果为0,则使用默认大小。
【CreateProcess函数】
BOOL CreateProcess(
LPCTSTR lpApplicationName,
LPTSTR lpCommandLine,
LPSECURITY_ATTRIBUTES lpProcessAttributes,
LPSECURITY_ATTRIBUTES lpThreadAttributes,
BOOL bInheritHandles,
DWORD dwCreationFlags,
LPVOID lpEnvironment,
LPCTSTR lpCurrentDirectory,
LPSTARTUPINFO lpStartupInfo,
LPPROCESS_INFORMATION lpProcessInformation
);
lpApplicationName:可执行文件的名称(可选)。
lpCommandLine:命令行参数。
lpProcessAttributes和lpThreadAttributes:指向SECURITY_ATTRIBUTES结构的指针,用于指定进程和线程的安全属性。
bInheritHandles:指示新进程是否继承父进程的句柄。
dwCreationFlags:指定进程的创建标志。
lpEnvironment:指定新进程的环境变量(可选)。
lpCurrentDirectory:指定新进程的当前工作目录(可选)。
lpStartupInfo:指向STARTUPINFO结构的指针,用于指定新进程的主窗口外观和其他属性。
lpProcessInformation:指向PROCESS_INFORMATION结构的指针,用于接收新进程的相关信息,如进程句柄、主线程句柄等。
使用示例:
HANDLE hReadPipe, hWritePipe;
SECURITY_ATTRIBUTES sa;
sa.nLength = sizeof(SECURITY_ATTRIBUTES);
sa.bInheritHandle = TRUE; // 允许子进程继承句柄
sa.lpSecurityDescriptor = NULL;
// 创建管道
if (!CreatePipe(&hReadPipe, &hWritePipe, &sa, 0)) {
// 处理创建管道失败的情况
return;
}
STARTUPINFO si;
PROCESS_INFORMATION pi;
ZeroMemory(&si, sizeof(STARTUPINFO));
si.cb = sizeof(STARTUPINFO);
si.hStdError = hWritePipe; // 将标准错误输出重定向到管道写入端
si.hStdOutput = hWritePipe; // 将标准输出重定向到管道写入端
si.dwFlags |= STARTF_USESTDHANDLES; // 使用重定向句柄
// 创建进程
if (!CreateProcess(NULL, // 不指定可执行文件的名称
"executable.exe", // 命令行参数
NULL, // 进程安全属性
NULL, // 线程安全属性
TRUE, // 继承句柄
0, // 创建标志
NULL, // 环境变量
NULL, // 当前工作目录
&si, // STARTUPINFO
&pi // PROCESS_INFORMATION
)) {
// 处理创建进程失败的情况
return;
}
// 关闭管道的读端和写端
CloseHandle(hReadPipe);
CloseHandle(hWritePipe);
在上面的示例中,CreatePipe函数被用于创建一个匿名管道,其中hReadPipe用于读取数据,hWritePipe用于写入数据。CreateProcess函数创建一个新的进程,并将标准输出和标准错误输出重定向到管道的写入端,使得子进程的输出可以通过管道传递给主进程。最后,通过CloseHandle函数关闭管道的读端和写端。