::命名管道不但能实现同一台机器上两个进程通信,还能在网络中不同机器上的两个进程之间的通信机制。与邮槽不同,命名管道是采用基于连接并且可靠的传输方式,所以命名管道传输数据只能一对一进行传输。

[C++] socket -8 [命名管道]-LMLPHP

[C++] socket -8 [命名管道]-LMLPHP

[C++] socket -8 [命名管道]-LMLPHP

 /*
命名管道服务器
*/
#include<windows.h>
#include<stdio.h>
int main()
{
HANDLE hpip;//定义命名管道句柄
OVERLAPPED ovi={};//定义结构体变量
char buf[];//定义数据缓冲区
DWORD readbuf;//获取实际读取字节数
hpip=CreateNamedPipe("\\\\.\\pipe\\pipename",PIPE_ACCESS_DUPLEX,
PIPE_TYPE_BYTE,PIPE_UNLIMITED_INSTANCES,,,,NULL);//创建命名管道
printf("创建管道成功,正在等待客户端连接!\r\n");
if(::ConnectNamedPipe(hpip,&ovi))//等待客户端的连接请求
{
printf("客户端连接成功\r\n");
printf("正在读取数据!\r\n");
if(ReadFile(hpip,buf,,&readbuf,NULL))//读取管道数据
{
printf("读取数据成功!\r\n");
printf("读取数据是: %s\r\n",buf);
}
else
{
printf("读取数据失败\r\n");
}
}
::Sleep();
return ;
}
 /*
命名管道客户端
*/
#include<windows.h>
#include<stdio.h>
int main()
{
HANDLE hpip;
OVERLAPPED ovi={};
char buf[]="命名管道测试程序!\r\n";//定义数据缓冲区
DWORD readbuf;//定义结构体变量
printf("正在连接命名管道!\r\n");
if(WaitNamedPipe("\\\\.\\pipe\\pipename",NMPWAIT_WAIT_FOREVER))//连接命名管道
{
hpip=CreateFile("\\\\.\\pipe\\pipename",GENERIC_READ|GENERIC_WRITE,,
NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL);//打开指定命名管道
if(hpip==INVALID_HANDLE_VALUE)
{
printf("打开命名管道失败\r\n");
}
else
{
if(WriteFile(hpip,buf,sizeof(buf),&readbuf,NULL))//写入数据到管道
{
printf("数据写入成功!\r\n");
}
else
{
printf("数据写入失败\r\n");
}
}
}
else
{
printf("管道创建失败!\r\n");
}
::Sleep();
return ;
}
05-11 13:51