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
- Windows上C++使用命名管道进行进程间通讯
- Windows上C++使用共享内存进行进程间通讯
- Windows上C++使用WM_COPYDATA函数进行进程间通讯
- linux进程间通讯-命名管道
- 利用命名管道实现进程间通讯
- 进程通讯(命名管道)
- 父子进程通过管道通讯------命名管道
- Windows进程间通信之命名管道
- Windows进程间通信之命名管道
- Windows进程间通信—命名管道
- Windows进程间的通信-命名管道
- 使用命名管道通过网络在进程之间进行通信(C#)
- 【网络编程学习笔记03】进程间通讯-命名管道
- Delphi 使用管道进程间通讯
- Java使用管道实现进程间通讯
- Java使用管道实现进程间通讯
- 进程间通讯--管道
- 进程间通讯:管道
- allowTaskReparenting属性
- matplotlib 中文显示问题的解决办法
- Android实现View的任意拖动
- ARM NEON简介
- Android清单注册总结
- Windows上C++使用命名管道进行进程间通讯
- ajax 每10秒调用一次接口
- 一个小算法的优化
- JSONArray与Java对象之间的转换
- HDU 3966 Aragorn's Story(树链剖分)
- KMP算法
- Python之inspect模块实现获取加载模块路径
- 运算符
- 实现数据库与项目的链接