CreatePipe()等函数创建管道来操纵控制台

CreatePipe()等函数创建管道来操纵控制台#include  #include    #define BUFSIZE 4096   HANDLE hChildStdinRd, hChildStdinWr, hChildStdinWrDup,    hChildStdoutRd, hChildStdoutWr, hChildStdoutRdDup,    hInputFile, hStdout;   BO

大家好,又见面了,我是你们的朋友全栈君。

#include <stdio.h> 
#include <windows.h> 
  
#define BUFSIZE 4096 
  
HANDLE 
hChildStdinRd, hChildStdinWr, hChildStdinWrDup, 
   
hChildStdoutRd, hChildStdoutWr, hChildStdoutRdDup, 
   
hInputFile, hStdout; 
  
BOOL 
CreateChildProcess(
VOID
); 
VOID 
WriteToPipe(
VOID
); 
VOID 
ReadFromPipe(
VOID
); 
VOID 
ErrorExit(
LPTSTR
); 
VOID 
ErrMsg(
LPTSTR

BOOL
); 
  
DWORD 
main(
int 
argc, 
char 
*argv[]) 
   
SECURITY_ATTRIBUTES saAttr; 
   
BOOL 
fSuccess; 
  
// Set the bInheritHandle flag so pipe handles are inherited. 
  
   
saAttr.nLength = 
sizeof
(SECURITY_ATTRIBUTES); 
   
saAttr.bInheritHandle = TRUE; 
   
saAttr.lpSecurityDescriptor = NULL; 
  
// Get the handle to the current STDOUT. 
  
   
hStdout = GetStdHandle(STD_OUTPUT_HANDLE); 
  
// Create a pipe for the child process's STDOUT. 
  
   
if 
(! CreatePipe(&hChildStdoutRd, &hChildStdoutWr, &saAttr, 0)) 
      
ErrorExit(
"Stdout pipe creation failed\n"
); 
  
// Create noninheritable read handle and close the inheritable read 
// handle. 
 
    
fSuccess = DuplicateHandle(GetCurrentProcess(), hChildStdoutRd,
        
GetCurrentProcess(), &hChildStdoutRdDup , 0,
        
FALSE,
        
DUPLICATE_SAME_ACCESS);
    
if
( !fSuccess )
        
ErrorExit(
"DuplicateHandle failed"
);
    
CloseHandle(hChildStdoutRd);
 
// Create a pipe for the child process's STDIN. 
  
   
if 
(! CreatePipe(&hChildStdinRd, &hChildStdinWr, &saAttr, 0)) 
      
ErrorExit(
"Stdin pipe creation failed\n"
); 
  
// Duplicate the write handle to the pipe so it is not inherited. 
  
   
fSuccess = DuplicateHandle(GetCurrentProcess(), hChildStdinWr, 
      
GetCurrentProcess(), &hChildStdinWrDup, 0, 
      
FALSE,                  
// not inherited 
      
DUPLICATE_SAME_ACCESS); 
   
if 
(! fSuccess) 
      
ErrorExit(
"DuplicateHandle failed"
); 
  
   
CloseHandle(hChildStdinWr); 
  
// Now create the child process. 
    
   
fSuccess = CreateChildProcess();
   
if 
(! fSuccess) 
      
ErrorExit(
"Create process failed"
); 
 
// Get a handle to the parent's input file. 
  
   
if 
(argc == 1) 
      
ErrorExit(
"Please specify an input file"
);
 
   
hInputFile = CreateFile(argv[1], GENERIC_READ, 0, NULL, 
      
OPEN_EXISTING, FILE_ATTRIBUTE_READONLY, NULL); 
  
   
if 
(hInputFile == INVALID_HANDLE_VALUE) 
      
ErrorExit(
"CreateFile failed\n"
); 
  
// Write to pipe that is the standard input for a child process. 
  
   
WriteToPipe(); 
  
// Read from pipe that is the standard output for child process. 
  
   
ReadFromPipe(); 
  
   
return 
0; 
  
BOOL 
CreateChildProcess() 
   
PROCESS_INFORMATION piProcInfo; 
   
STARTUPINFO siStartInfo;
   
BOOL 
bFuncRetn = FALSE; 
  
// Set up members of the PROCESS_INFORMATION structure. 
  
   
ZeroMemory( &piProcInfo, 
sizeof
(PROCESS_INFORMATION) );
  
// Set up members of the STARTUPINFO structure. 
  
   
ZeroMemory( &siStartInfo, 
sizeof
(STARTUPINFO) );
   
siStartInfo.cb = 
sizeof
(STARTUPINFO); 
   
siStartInfo.hStdError = hChildStdoutWr;
   
siStartInfo.hStdOutput = hChildStdoutWr;
   
siStartInfo.hStdInput = hChildStdinRd;
   
siStartInfo.dwFlags |= STARTF_USESTDHANDLES;
  
// Create the child process. 
     
   
bFuncRetn = CreateProcess(NULL, 
      
"child"
,       
// command line 
      
NULL,          
// process security attributes 
      
NULL,          
// primary thread security attributes 
      
TRUE,          
// handles are inherited 
      
0,             
// creation flags 
      
NULL,          
// use parent's environment 
      
NULL,          
// use parent's current directory 
      
&siStartInfo,  
// STARTUPINFO pointer 
      
&piProcInfo);  
// receives PROCESS_INFORMATION 
    
   
if 
(bFuncRetn == 0) 
      
ErrorExit(
"CreateProcess failed"
);
   
else 
   
{
      
CloseHandle(piProcInfo.hProcess);
      
CloseHandle(piProcInfo.hThread);
      
return 
bFuncRetn;
   
}
}
  
VOID 
WriteToPipe(
VOID
   
DWORD 
dwRead, dwWritten; 
   
CHAR 
chBuf[BUFSIZE]; 
  
// Read from a file and write its contents to a pipe. 
  
   
for 
(;;) 
   
      
if 
(! ReadFile(hInputFile, chBuf, BUFSIZE, &dwRead, NULL) || 
         
dwRead == 0) 
break
      
if 
(! WriteFile(hChildStdinWrDup, chBuf, dwRead, 
         
&dwWritten, NULL)) 
break
   
  
// Close the pipe handle so the child process stops reading. 
  
   
if 
(! CloseHandle(hChildStdinWrDup)) 
      
ErrorExit(
"Close pipe failed"
); 
  
VOID 
ReadFromPipe(
VOID
   
DWORD 
dwRead, dwWritten; 
   
CHAR 
chBuf[BUFSIZE]; 
 
// Close the write end of the pipe before reading from the 
// read end of the pipe. 
  
   
if 
(!CloseHandle(hChildStdoutWr)) 
      
ErrorExit(
"CloseHandle failed"
); 
  
// Read output from the child process, and write to parent's STDOUT. 
  
   
for 
(;;) 
   
      
if
( !ReadFile( hChildStdoutRdDup, chBuf, BUFSIZE, &dwRead, 
         
NULL) || dwRead == 0) 
break
      
if 
(! WriteFile(hStdout, chBuf, dwRead, &dwWritten, NULL)) 
         
break
   
  
VOID 
ErrorExit (
LPTSTR 
lpszMessage) 
   
fprintf
(stderr, 
"%s\n"
, lpszMessage); 
   
ExitProcess(0); 
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/159417.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号