【转】C++ 进程间的通讯(一):简单的有名管道实现
--------------------------------------------------
进程间的通讯(一):简单的有名管道实现
一 管道简介
二 实现代码
Server Code:
- #include "stdafx.h"
- #include <stdio.h>
- #include <windows.h>
- #include <ctime>
- int main(int argc, _TCHAR* argv[])
- {
- srand(time(NULL));
- char buf[256] = "";
- DWORD rlen = 0;
- HANDLE hPipe = CreateNamedPipe(
- TEXT("\\\\.\\Pipe\\mypipe"), //管道名
- PIPE_ACCESS_DUPLEX, //管道类型
- PIPE_TYPE_MESSAGE|PIPE_READMODE_MESSAGE|PIPE_WAIT, //管道参数
- PIPE_UNLIMITED_INSTANCES, //管道能创建的最大实例数量
- 0, //输出缓冲区长度 0表示默认
- 0, //输入缓冲区长度 0表示默认
- NMPWAIT_WAIT_FOREVER, //超时时间
- NULL); //指定一个SECURITY_ATTRIBUTES结构,或者传递零值.
- if (INVALID_HANDLE_VALUE == hPipe)
- {
- printf("Create Pipe Error(%d)\n",GetLastError());
- }
- else
- {
- printf("Waiting For Client Connection...\n");
- if(ConnectNamedPipe(hPipe, NULL)==NULL) //阻塞等待客户端连接。
- {
- printf("Connection failed!\n");
- }
- else
- {
- printf("Connection Success!\n");
- }
- while (true)
- {
- if(ReadFile(hPipe,buf,256,&rlen,NULL)==FALSE) //接受客户端发送过来的内容
- {
- printf("Read Data From Pipe Failed!\n");
- break;
- }
- else
- {
- printf("From Client: data = %s, size = %d\n", buf, rlen);
- char wbuf[256] = "";
- sprintf(wbuf, "%s%d", wbuf, rand()%1000);
- DWORD wlen = 0;
- WriteFile(hPipe, wbuf, sizeof(wbuf), &wlen, 0); //向客户端发送内容
- printf("To Client: data = %s, size = %d\n", wbuf, wlen);
- Sleep(1000);
- }
- }
- CloseHandle(hPipe);//关闭管道
- }
- system("PAUSE");
- return 0;
- }
Clietn Code:
- #include "stdafx.h"
- #include <stdio.h>
- #include <windows.h>
- #include <ctime>
- int main(int argc, _TCHAR* argv[])
- {
- srand(time(NULL));
- DWORD wlen = 0;
- Sleep(1000);//等待pipe的创建成功!
- BOOL bRet = WaitNamedPipe(TEXT("\\\\.\\Pipe\\mypipe"), NMPWAIT_WAIT_FOREVER);
- if (!bRet)
- {
- printf("connect the namedPipe failed!\n");
- return 0;
- }
- HANDLE hPipe=CreateFile( //管道属于一种特殊的文件
- TEXT("\\\\.\\Pipe\\mypipe"), //创建的文件名
- GENERIC_READ | GENERIC_WRITE, //文件模式
- 0, //是否共享
- NULL, //指向一个SECURITY_ATTRIBUTES结构的指针
- OPEN_EXISTING, //创建参数
- FILE_ATTRIBUTE_NORMAL, //文件属性(隐藏,只读)NORMAL为默认属性
- NULL); //模板创建文件的句柄
- if (INVALID_HANDLE_VALUE == hPipe)
- {
- printf("open the exit pipe failed!\n");
- }
- else
- {
- while(true)
- {
- char buf[256] = "";
- sprintf(buf,"%s%d",buf,rand()%1000);
- if(WriteFile(hPipe,buf,sizeof(buf),&wlen,0)==FALSE) //向服务器发送内容
- {
- printf("write to pipe failed!\n");
- break;
- }
- else
- {
- printf("To Server: data = %s, size = %d\n", buf, wlen);
- char rbuf[256] = "";
- DWORD rlen = 0;
- ReadFile(hPipe, rbuf, sizeof(rbuf), &rlen, 0); //接受服务发送过来的内容
- printf("From Server: data = %s, size = %d\n", rbuf, rlen);
- }
- Sleep(1000);
- }
- CloseHandle(hPipe);//关闭管道
- }
- system("PAUSE");
- return 0;
- }
【转】C++ 进程间的通讯(一):简单的有名管道实现的更多相关文章
- 进程间的通讯(IPC)方式
内存映射 为什么要进行进程间的通讯(IPC (Inter-process communication)) 数据传输:一个进程需要将它的数据发送给另一个进程,发送的数据量在一个字节到几M字节之间共享数据 ...
- [转]WINDOW进程间数据通讯以及共享内存
1.引言 在Windows程序中,各个进程之间常常需要交换数据,进行数据通讯.WIN32 API提供了许多函数使我们能够方便高效地进行进程间的通讯,通过这些函数我们可以控制不同进程间的数据交换,就如同 ...
- 8.7 进程间的通讯:管道、消息队列、共享内存、信号量、信号、Socket
进程间的通讯 进程间为什么需要通讯? 共享数据.数据传输.消息通知.进程控制 进程间的通讯有哪些类型? 首先,联系前面讲过的知识,进程之间的用户地址空间是相互独立的,不能进行互相访问,但是,内核空间却 ...
- .Net下的进程间的通讯 -- Windows消息队列
Windows 消息队列(MSMQ),是微软Windows2000以上的操作系统的一个服务,可以提供在计算机间消息的可靠传输,用来在两个进程间进行异步通讯最合适不过了.在.Net中有一个Message ...
- AIDL机制实现进程间的通讯实例
转载自:http://blog.csdn.net/cjjky/article/details/7562652 ======================================= 在Andr ...
- 进程间的通讯————IPC
""" IPC 指的是进程间通讯 之所以开启子进程 肯定需要它帮我们完成任务 很多情况下 需要将数据返回给父进程 然而 进程内存是物理隔离的 解决方案: 1.将共享数据放 ...
- 进程之间的通讯Queue简单应用
#进程间通讯--Queue #Process有时需要通信的,操作系统提供了很多机制来实现进程之间的通讯 #而Queue就是其中一个 #1.Queue的使用 #可以使用multiprocessing模块 ...
- python进程间的通讯实现
1:进程间通讯的方法:apply_async()非阻塞式通讯 apply()阻塞式通讯 2:使用Queue实现对Process创建的进程间通讯, Queue本身是一个消息队列程序,Queue常 ...
- 一个进程间同步和通讯的 C# 框架
转自原文 一个进程间同步和通讯的 C# 框架 threadmsg_demo.zip ~ 41KB 下载 threadmsg_src.zip ~ 65KB 下载 0.背景简介 微软在 .NE ...
随机推荐
- iTOP-4418开发板最新资料及例程
开发板资料: 开发板硬件资源: 1.POWER电源接口 电源输入为 5V/2A+,给核心板 AXP228 电源管理芯片提供 5V 电源. 2.SWITCH电源开关 轻触电源开关可以控制开发板电源通断. ...
- maven多模块项目,多web合并项目使用心得
Fixflow,做中国最好的开源流程引擎!项目地址https://github.com/fixteam/fixflow 此文章适合maven初学者或想接触maven的用户,讲的只是皮毛,高手请自觉略过 ...
- 获取tomcat服务器上的部分日志
Linux下tomcat的日志很大,有的几G大,要用什么工具查看或把日志文件拆解? 一般习惯用 tail 的方式在服务器查看.如果要取下 可以用 tail -2000 xxxx.log > te ...
- 手机端打开调试工具,模拟console.log
将下列代码考入需要调试页面即可 <script src="//cdn.jsdelivr.net/npm/eruda"></script> <scrip ...
- Mac OS 使用asio库
下载地址:http://sourceforge.net/projects/asio/files/asio/1.12.2%20%28Stable%29/ 本人下载的版本:asio-1.12.2 1,本人 ...
- lua 之 and or not
and是与运算,返回值如下 如果前者为false或者nil,则返回前者,否则后者 A and B 类似如下语句 if not A then return A else return B end 总结: ...
- jQuery动态移除和绑定事件
function bindEvent() { //移除绑定事件 $('.btnsp').unbind('click'); //绑定事件 $('.btnsp').bind('click', functi ...
- hdfs深入:07、hdfs的文件的读取过程
详细步骤解析 1. Client向NameNode发起RPC请求,来确定请求文件block所在的位置: 2. NameNode会视情况返回文件的部分或者全部block列表,对于每个block,Name ...
- Redux的中间件Middleware不难,我信了^_^
Redux的action和reducer已经足够复杂了,现在还需要理解Redux的中间件.为什么Redux的存在有何意义?为什么Redux的中间件有这么多层的函数返回?Redux的中间件究竟是如何工作 ...
- hdu 1792 A New Change Problem(互质数之间最大不能组合数和不能组合数的个数)
题意:求互质的m和n的最大不能组合数和不能组合数的个数 思路:m和n的最大不能组合数为m*n-m-n,不能组合数的个数为(m-1)*(n-1)/2 推导: 先讨论最大不能组合数 因为gcd(m,n)= ...