原文: C++ 进程间的通讯(一):简单的有名管道实现

--------------------------------------------------

进程间的通讯(一):简单的有名管道实现

 

一 管道简介

命名管道(Named Pipe)是服务器进程和一个或多个客户进程之间通信的单向或双向管道。不同于匿名管道的是命名管道可以在不相关的进程之间和不同计算机之间使用,服务器建立命名管道时给它指定一个名字,任何进程都可以通过该名字打开管道的另一端,根据给定的权限和服务器进程通信。
其优点是实现起来比较简单方便.
缺点是会使进程之间的代码耦合度增加.并且管道通信只适用于同一台主机上的进程之间通讯.

二 实现代码

Server Code:

  1. #include "stdafx.h"
  2. #include <stdio.h>
  3. #include <windows.h>
  4. #include <ctime>
  5. int main(int argc, _TCHAR* argv[])
  6. {
  7. srand(time(NULL));
  8. char buf[256] = "";
  9. DWORD rlen = 0;
  10. HANDLE hPipe = CreateNamedPipe(
  11. TEXT("\\\\.\\Pipe\\mypipe"),                        //管道名
  12. PIPE_ACCESS_DUPLEX,                                 //管道类型
  13. PIPE_TYPE_MESSAGE|PIPE_READMODE_MESSAGE|PIPE_WAIT,  //管道参数
  14. PIPE_UNLIMITED_INSTANCES,                           //管道能创建的最大实例数量
  15. 0,                                                  //输出缓冲区长度 0表示默认
  16. 0,                                                  //输入缓冲区长度 0表示默认
  17. NMPWAIT_WAIT_FOREVER,                               //超时时间
  18. NULL);                                                  //指定一个SECURITY_ATTRIBUTES结构,或者传递零值.
  19. if (INVALID_HANDLE_VALUE == hPipe)
  20. {
  21. printf("Create Pipe Error(%d)\n",GetLastError());
  22. }
  23. else
  24. {
  25. printf("Waiting For Client Connection...\n");
  26. if(ConnectNamedPipe(hPipe, NULL)==NULL) //阻塞等待客户端连接。
  27. {
  28. printf("Connection failed!\n");
  29. }
  30. else
  31. {
  32. printf("Connection Success!\n");
  33. }
  34. while (true)
  35. {
  36. if(ReadFile(hPipe,buf,256,&rlen,NULL)==FALSE) //接受客户端发送过来的内容
  37. {
  38. printf("Read Data From Pipe Failed!\n");
  39. break;
  40. }
  41. else
  42. {
  43. printf("From Client: data = %s, size = %d\n", buf, rlen);
  44. char wbuf[256] = "";
  45. sprintf(wbuf, "%s%d", wbuf, rand()%1000);
  46. DWORD wlen = 0;
  47. WriteFile(hPipe, wbuf, sizeof(wbuf), &wlen, 0); //向客户端发送内容
  48. printf("To Client: data = %s, size = %d\n", wbuf, wlen);
  49. Sleep(1000);
  50. }
  51. }
  52. CloseHandle(hPipe);//关闭管道
  53. }
  54. system("PAUSE");
  55. return 0;
  56. }

Clietn Code:

  1. #include "stdafx.h"
  2. #include <stdio.h>
  3. #include <windows.h>
  4. #include <ctime>
  5. int main(int argc, _TCHAR* argv[])
  6. {
  7. srand(time(NULL));
  8. DWORD wlen = 0;
  9. Sleep(1000);//等待pipe的创建成功!
  10. BOOL bRet = WaitNamedPipe(TEXT("\\\\.\\Pipe\\mypipe"), NMPWAIT_WAIT_FOREVER);
  11. if (!bRet)
  12. {
  13. printf("connect the namedPipe failed!\n");
  14. return 0;
  15. }
  16. HANDLE hPipe=CreateFile(            //管道属于一种特殊的文件
  17. TEXT("\\\\.\\Pipe\\mypipe"),    //创建的文件名
  18. GENERIC_READ | GENERIC_WRITE,   //文件模式
  19. 0,                              //是否共享
  20. NULL,                           //指向一个SECURITY_ATTRIBUTES结构的指针
  21. OPEN_EXISTING,                  //创建参数
  22. FILE_ATTRIBUTE_NORMAL,          //文件属性(隐藏,只读)NORMAL为默认属性
  23. NULL);                          //模板创建文件的句柄
  24. if (INVALID_HANDLE_VALUE == hPipe)
  25. {
  26. printf("open the exit pipe failed!\n");
  27. }
  28. else
  29. {
  30. while(true)
  31. {
  32. char buf[256] = "";
  33. sprintf(buf,"%s%d",buf,rand()%1000);
  34. if(WriteFile(hPipe,buf,sizeof(buf),&wlen,0)==FALSE) //向服务器发送内容
  35. {
  36. printf("write to pipe failed!\n");
  37. break;
  38. }
  39. else
  40. {
  41. printf("To Server: data = %s, size = %d\n", buf, wlen);
  42. char rbuf[256] = "";
  43. DWORD rlen = 0;
  44. ReadFile(hPipe, rbuf, sizeof(rbuf), &rlen, 0);  //接受服务发送过来的内容
  45. printf("From Server: data = %s, size = %d\n", rbuf, rlen);
  46. }
  47. Sleep(1000);
  48. }
  49. CloseHandle(hPipe);//关闭管道
  50. }
  51. system("PAUSE");
  52. return 0;
  53. }

【转】C++ 进程间的通讯(一):简单的有名管道实现的更多相关文章

  1. 进程间的通讯(IPC)方式

    内存映射 为什么要进行进程间的通讯(IPC (Inter-process communication)) 数据传输:一个进程需要将它的数据发送给另一个进程,发送的数据量在一个字节到几M字节之间共享数据 ...

  2. [转]WINDOW进程间数据通讯以及共享内存

    1.引言 在Windows程序中,各个进程之间常常需要交换数据,进行数据通讯.WIN32 API提供了许多函数使我们能够方便高效地进行进程间的通讯,通过这些函数我们可以控制不同进程间的数据交换,就如同 ...

  3. 8.7 进程间的通讯:管道、消息队列、共享内存、信号量、信号、Socket

    进程间的通讯 进程间为什么需要通讯? 共享数据.数据传输.消息通知.进程控制 进程间的通讯有哪些类型? 首先,联系前面讲过的知识,进程之间的用户地址空间是相互独立的,不能进行互相访问,但是,内核空间却 ...

  4. .Net下的进程间的通讯 -- Windows消息队列

    Windows 消息队列(MSMQ),是微软Windows2000以上的操作系统的一个服务,可以提供在计算机间消息的可靠传输,用来在两个进程间进行异步通讯最合适不过了.在.Net中有一个Message ...

  5. AIDL机制实现进程间的通讯实例

    转载自:http://blog.csdn.net/cjjky/article/details/7562652 ======================================= 在Andr ...

  6. 进程间的通讯————IPC

    """ IPC 指的是进程间通讯 之所以开启子进程 肯定需要它帮我们完成任务 很多情况下 需要将数据返回给父进程 然而 进程内存是物理隔离的 解决方案: 1.将共享数据放 ...

  7. 进程之间的通讯Queue简单应用

    #进程间通讯--Queue #Process有时需要通信的,操作系统提供了很多机制来实现进程之间的通讯 #而Queue就是其中一个 #1.Queue的使用 #可以使用multiprocessing模块 ...

  8. python进程间的通讯实现

    1:进程间通讯的方法:apply_async()非阻塞式通讯     apply()阻塞式通讯 2:使用Queue实现对Process创建的进程间通讯, Queue本身是一个消息队列程序,Queue常 ...

  9. 一个进程间同步和通讯的 C# 框架

    转自原文 一个进程间同步和通讯的 C# 框架 threadmsg_demo.zip ~ 41KB    下载 threadmsg_src.zip ~ 65KB    下载 0.背景简介 微软在 .NE ...

随机推荐

  1. Tinking in Java ---Java的NIO和对象序列化

    前面一篇博客的IO被称为经典IO,因为他们大多数都是从Java1.0开始就有了的:然后今天这篇博客是关于NIO的,所以的NIO其实就是JDK从1.4开始,Java提供的一系列改进的输入/输出处理的新功 ...

  2. 合并百度影音的离线数据 with python 2.2 bdv格式的更新

    百度影音的bdv格式又有变化. 此次存在2种bdv格式. 格式1:每个文件夹内就一个bdv文件,文件合并后改名avi即可. 格式2:每个文件夹内一个bdv文件作为索引,其他附加guid的文件作为数据. ...

  3. Matlab基础之单元数组和结构数组

    Matlab基础之单元数组和结构数组 前言: 单元数组和结构数组是一种新的数据类型,能将不同类型.不同维数的数组组合在一起,从而方便对不同的数据类型方便管理和维护. 如上图所示的2*2矩阵中,分别存储 ...

  4. mysql-oracle

    1.oracle数据崩导入时部分字段数据太长导入失败:原因是两边oracle字符集不一致 https://www.cnblogs.com/baoposhou/p/5669778.html 2.orac ...

  5. Friday Q&A 2015-11-20:协变与逆变

    作者:Mike Ash,原文链接,原文日期:2015-11-20译者:Cee:校对:千叶知风:定稿:numbbbbb 在现代的编程语言中,子类型(Subtypes)和超类型(Supertypes)已经 ...

  6. 使用Gson解析Json数组遇到的泛型类型擦除问题解决方法

    谷歌Gson转换Json串有如下方法: public Object fromJson(String json, Type typeOfT);1可以使用它进行数组解析.如下,使用此方法解析Json串为类 ...

  7. 模拟Java-Sping,实现其IOC和AOP核心

    简易的IOC框图 注解的方式实现了左边的分支,那么就剩下右边的XML分支: XmlContext:这个类是也是AbstractApplicationContext的子类,和AnnotationCont ...

  8. eigenface资料整合

    把图片映射到能最好区分的空间(pca),在这个空间同类是聚集的,而不同类之间间隔大.这相当于一个模型,把验证集也映射到此空间,然后利用knn对验证集分类. pca:https://wenku.baid ...

  9. SpringCloud 微服务框架

    学习资源:https://ke.qq.com/course/280057 知识体系分为以下几点: 1)使用Eureka搭建注册中心,包括 服务生产者.服务消费者(也称服务注册与发现): Zookeep ...

  10. 自动交互脚本之expect使用记录

    之前一直没怎么用这个命令,意外用了一下,还不错,那这个是干嘛的呢 我们或多或少会远程登录其他服务器,需要执行某项任务,通常需要手动接入,输入密码啊,等等 那我们如何有效的自动执行呢,expect可以解 ...