Windows进程通信方式之匿名管道

 父进程:

1.创建一个匿名管道

BOOL WINAPI CreatePipe(

  __out         PHANDLE hReadPipe,

  __out         PHANDLE hWritePipe,

  __in          LPSECURITY_ATTRIBUTES lpPipeAttributes,

  __in          DWORD nSize

);

创建一个匿名管道,返回管道的读写句柄。其中第三个参数是一个指向SECURITY_ATTRIBUTES结构的指针,它用来决定返回的句柄是否能被子进程所继承。通常被设为NULL,编写匿名管道时不可以。因为管道只可以在父子进程之间进行通信。

typedef struct _SECURITY_ATTRIBUTES {
  DWORD nLength;
  LPVOID lpSecurityDescriptor;
  BOOL bInheritHandle;

} SECURITY_ATTRIBUTES, *PSECURITY_ATTRIBUTES, *LPSECURITY_ATTRIBUTES;

第三个参数用来所返回的句柄是否可以被新的子进程所继承,设为TRUE表示可以。

2.创建成功后,应当启动子进程,利用函数CreateProcess();

子进程:

在子进程中得到管道的句柄

HANDLE WINAPI GetStdHandle(

  __in          DWORD nStdHandle

);

具体程序如下:

父进程:

void CParentView::OnPipeCreate()
{
 // TODO: 在此添加命令处理程序代码
    SECURITY_ATTRIBUTES sa;
 sa.bInheritHandle=TRUE;
 sa.lpSecurityDescriptor=NULL;
 sa.nLength=sizeof(SECURITY_ATTRIBUTES );
 if(!CreatePipe(&hRead,&hWrite,&sa,0))
 {
  MessageBox("创建匿名管道失败");
  return;
 }
    STARTUPINFO sui;
    PROCESS_INFORMATION pi;
 ZeroMemory(&sui,sizeof(STARTUPINFO));//将结构体中成员全置为0,因为我们只是用了其中几个,否则其它都是随机的
 sui.cb=sizeof(STARTUPINFO);
 sui.dwFlags=STARTF_USESTDHANDLES;
 sui.hStdInput=hRead;
 sui.hStdOutput=hWrite;
 sui.hStdError=GetStdHandle(STD_ERROR_HANDLE);

    if(!CreateProcess("..\\Child\\Debug\\Child.exe",NULL,NULL,NULL,TRUE,0,NULL,NULL,&sui,&pi))
 {
  CloseHandle(hRead);
  CloseHandle(hWrite);
  hRead=NULL;
  hWrite=NULL;
  MessageBox("创建子进程失败");
  return;
 }
 else
 {
  CloseHandle(pi.hProcess);
  CloseHandle(pi.hThread);
 }
}

子进程:

void CChildView::OnInitialUpdate(void)
{
 hRead=GetStdHandle(STD_INPUT_HANDLE);
 hWrite=GetStdHandle(STD_OUTPUT_HANDLE);
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值