Windows上C++使用命名管道进行进程间通讯

来源:互联网 发布:高端 商务礼品 知乎 编辑:程序博客网 时间:2024/06/06 01:08

命名管道是通过网络来完成进程间的通信 , 它屏蔽了底层的网络协议细节 ; 我们在不了解网络协议的情况下 , 也可以利用命名管道来实现进程间的通信 ; 与 Socket 网络通信相比 , 命名管道不再需要编写身份验证的代码 ; 将命名管道作为一种网络编程方案时 , 它实际上建立了一个 C/S 通信体系 , 并在其中可靠的传输数据 ; 命名管道服务器和客户机的区别在于 : 服务器是唯一一个有权创建命名管道的进程 , 也只有它能接受管道客户机的连接请求 , 而客户机只能同一个现成的命名管道服务器建立连接 ; 示例代码如下 :

服务端代码 :

#include "stdafx.h"#include "windows.h"#include <iostream>using namespace std;#define BUF_SIZE 4096// 定义管道名 , 如果是跨网络通信 , 则在圆点处指定服务器端程序所在的主机名#define EXAMP_PIPE   L"\\\\.\\pipe\\ReadPipe"   int _tmain(int argc, TCHAR* argv[], TCHAR* envp[]){    // 创建命名管道    HANDLE hPipe = NULL;    hPipe = CreateNamedPipe(         EXAMP_PIPE,                     PIPE_ACCESS_DUPLEX,               PIPE_TYPE_MESSAGE |            PIPE_READMODE_MESSAGE |          PIPE_WAIT,                       PIPE_UNLIMITED_INSTANCES,         BUF_SIZE,                 BUF_SIZE,        0,        NULL);                if (hPipe==INVALID_HANDLE_VALUE)    {        cout<<"Create Read Pipe Error"<<endl;        return FALSE;    }    // 等待客户端的连接    if (!ConnectNamedPipe(hPipe, NULL))    {        cout<<"Connect Failed"<<endl;        return FALSE;    }    DWORD dwReturn = 0;    char szBuffer[BUF_SIZE] = {0};    // 向客户端发送数据    cin>>szBuffer;       if (!WriteFile(hPipe,szBuffer,strlen(szBuffer),&dwReturn,NULL))    {        cout<<"Write Failed"<<endl;    }    // 读取客户端数据    memset(szBuffer, 0, BUF_SIZE);    if (ReadFile(hPipe,szBuffer,BUF_SIZE,&dwReturn,NULL))    {        szBuffer[dwReturn] = '\0';        cout<<szBuffer<<endl;    }    else    {        cout<<"Read Failed"<<endl;    }    DisconnectNamedPipe(hPipe);    CloseHandle(hPipe);    return 0;}

客户端代码 :

#include "stdafx.h"#include "windows.h"#include <iostream>using namespace std;#define BUF_SIZE 4096// 定义管道名 , 如果是跨网络通信 , 则在圆点处指定服务器端程序所在的主机名#define EXAMP_PIPE   L"\\\\.\\pipe\\ReadPipe"int _tmain(int argc, TCHAR* argv[], TCHAR* envp[]){    HANDLE hPipe = NULL;    char  szBuffer[BUF_SIZE] = {0};    DWORD dwReturn = 0;    // 判断是否有可以利用的命名管道      if (!WaitNamedPipe(EXAMP_PIPE, NMPWAIT_USE_DEFAULT_WAIT))    {        cout<<"No Read Pipe Accessible"<<endl;        return 0;      }      // 打开可用的命名管道 , 并与服务器端进程进行通信      hPipe = CreateFile(EXAMP_PIPE,GENERIC_READ | GENERIC_WRITE,        FILE_SHARE_READ | FILE_SHARE_WRITE,        NULL,OPEN_EXISTING,0,NULL);    if (hPipe==INVALID_HANDLE_VALUE)    {        cout<<"Open Read Pipe Error"<<endl;        return 0;      }    // 读取服务端发来的数据    if (ReadFile(hPipe,szBuffer,BUF_SIZE,&dwReturn,NULL))    {        szBuffer[dwReturn] = '\0';        cout<<szBuffer<<endl;    }    else    {        cout<<"Read Failed"<<endl;    }    // 向服务端发送数据    memset(szBuffer, 0, BUF_SIZE);    cin>>szBuffer;    if (!WriteFile(hPipe,szBuffer,strlen(szBuffer),&dwReturn,NULL))    {        cout<<"Write Failed"<<endl;    }    CloseHandle(hPipe);    return 0;}

个人网站: Github , 欢迎点击给星

0 0