IPC进程间通信+管道Pipe

      
        IPC(Inter-Process Communication。进程间通信)。

        管道用于进程间共享数据,事实上质是共享内存。经常使用IPC之中的一个。

管道不仅能够用于本机进程间通信,还可实现跨网络进程间通信。如同Socket通信。管道相同封装计算机底层网络实现,提供一个良好的API接口。

       
       1.管道(Pipe):


       管道分为匿名管道和命名管道。
       匿名管道仅仅能用于父子进程间通信 ,不能跨网络通信,而且通信是单向。

       命名管道可用于随意进程间通信。支持跨网络通信,而且通信是双向。随意一段都能够接收和发送数据。

命名管道是学习的重点。

       命名管道通信进程分为服务端和client,服务端创建Pipe,client通过管道名连接该Pipe之后。两方均可通过该Pipe发送和接收数据。
       
        2.邮槽命名 :
       本机上格式:\\ServerName\Pipe\name
       如:\\.\Pipe\my_pipe


       3.基本API函数 :
创建命名管道:
        HANDLE    CreateNamedPipe(

                        LPCTSTR   lpName,                // 指向管道名称的指针

                        DWORD     dwOpenMode,       // 管道打开模式

                        DWORD     dwPipeMode,
      // 管道模式

                        DWORD     nMaxInstances,     // 最大实例数

                        DWORD     nOutBufferSize,   // 输出缓存大小

                        DWORD     nInBufferSize,       // 输入缓存大小

                        DWORD    nDefaultTimeOut, // 超时设置

LPSECURITY_ATTRIBUTES lpSecurityAttributes   // 安全属性指针
);
        该函数用于server端创建命名管道。
等待client连接:
        BOOL  ConnectNamedPipe(

                     HANDLE    hNamedPipe,        //管道句柄

                     LPOVERLAPPED   lpOverlapped     //设为NULL

); 

        该函数用于server等待client连接到管道。

检查命名管道:
        BOOL  WaitNamedPipe(

                     LPCTSTR   lpNamedPipeName,  //管道名

                     DWORD     nTimeOut                  //超时

);
         该函数用于client检查是否存在管道Pipe。

打开命名管道:
        BOOL  CreateFile(
                     LPCTSTR   lpFileName,

                     DWORD     dwDesiredAccess,

                     DWORD     dwShareMode,

                     LPSECURITY_ATTRIBUTES   lpSecurityAttributes,

                     DWORD    dwCreationDisposition,

                     DWORD    dwFlagsAndAttributes,

                    HANDLE    hTemplateFile

);
         第一个參数:管道名指针。
         第二个參数:訪问模式。
         第三个參数:共享模式。
         第四个參数:安全属性指针。

         第五个參数:创建选项。
         第六个參数:文件属性。
         第七个參数:用于拷贝文件句柄。
         该函数用于打开一个管道。并返回管道句柄。
读取管道:       

BOOL ReadFile(

                    HANDLE    hFile,

                    LPVOID     lpBuffer,

                    DWORD    nNumberOfBytesToRead,

                    LPDOWRD    lpNumberOfBytesRead,

                    LPOVERLAPPED   lpOverlapped);

        第一个參数:管道句柄。
        第二个參数:缓存地址。

        第三个參数:消息的长度。
        第四个參数:实际读取的长度。

        第五个參数:一般设置为NULL。
        该函数用于读取管道内数据。
写入管道:
        BOOL  WriteFile(

                     HANDLE    hFile,

                     LPCVOID   lpBuffer,

                     DWORD     nNumberOfBytesToWrite,

                     LPDWORD   lpNumberOfBytesWritten,

                     LPOVERLAPPED    lpOverlapped);
         第一个參数:管道句柄。

         第二个參数:数据缓冲区指针。

         第三个參数:写入字节数。

         第四个參数:返回实际写入字节数。

         第五个參数:结构体指针。一般置NULL。

         该函数用于client向管道写入数据。


         4.牛刀小试 : 
         先在VC6.0中执行服务端程序。在执行client程序。

         执行效果:


server程序:

client程序:



【IPC进程间通讯之二】管道Pipe的更多相关文章

  1. 守护进程,进程安全,IPC进程间通讯,生产者消费者模型

    1.守护进程(了解)2.进程安全(*****) 互斥锁 抢票案例3.IPC进程间通讯 manager queue(*****)4.生产者消费者模型 守护进程 指的也是一个进程,可以守护着另一个进程 一 ...

  2. ipc 进程间通讯的AIDL

    1.什么是aidl:aidl是 Android Interface definition language的缩写,一看就明白,它是一种android内部进程通信接口的描述语言,通过它我们可以定义进程间 ...

  3. 【IPC进程间通讯之中的一个】邮槽MailSlot

    IPC进程间通信+邮槽MailSlot                IPC(Inter-Process Communication.进程间通信).        现代计算机採用虚拟内存机制,为进程提 ...

  4. android IPC 进程间通讯

    参考资料: http://blog.csdn.net/birdsaction/article/details/39451849 在这里我说一下学习技术的方法,别人的博客,别人的东西,再简单,自己没有写 ...

  5. 【IPC进程间通讯之三】内存映射文件Mapping File

    IPC进程间通信+共享内存Mapping                IPC(Inter-Process Communication.进程间通信).         文件映射(Mapping)是一种 ...

  6. 进程间通讯:有名管道FIFO

    接收端: #include <sys/stat.h> #include <sys/types.h> #include <stdio.h> #include < ...

  7. Android查缺补漏(IPC篇)-- 进程间通讯之Socket简介及示例

    本文作者:CodingBlock 文章链接:http://www.cnblogs.com/codingblock/p/8425736.html 进程间通讯篇系列文章目录: Android查缺补漏(IP ...

  8. 管道实现进程间通讯 、WaitNamedPipe

    一.管道实现进程间通讯 主要的理论知识 1.什么是管道以及分类 管道是两个头的东西,每一个头各连接一个进程或者同一个进程的不同代码,依照管道的类别分有两种管道,匿名的和命名的:依照管道的传输方向分也能 ...

  9. UNIX 进程间通讯(IPC)概念(Posix,System V IPC)

     IPC(Inter-Process Communication,进程间通讯)可以有三种信息共享方式(随文件系统,随内核,随共享内存).(当然这里虽然说是进程间通讯,其实也是可以和线程相通的). 相对 ...

随机推荐

  1. Python学习笔记(八)—集合的学习

    集合(set)是一个无序不重复元素的序列. 基本功能是进行成员关系测试和删除重复元素. 1.集合的作用 它可以把一个列表中重复的数据去掉,而不需要你再写判断 可以做关系测试,比如说有两个科目,一个数学 ...

  2. python类型比较的3种方式(转)

    通过types模块的类成员来判断,其实所有python中的类型都是这个types模块中类型的实例. import types type(x) is types.IntType # 判断是否int 类型 ...

  3. AES advanced encryption standard

    // advanced encryption standard // author: karl malbrain, malbrain@yahoo.com typedef unsigned char u ...

  4. JTAG Level Translation

    http://www.freelabs.com/~whitis/electronics/jtag/ One of the big issues in making a JTAG pod is leve ...

  5. 使用stream(流)实现多表数据传输

    使用stream(流)实现多表数据传输 几乎所有的TCP和HTTP通信控件都支持stream(流)的传输. 使用stream(流)是可以实现多表数据传输的. 但这需要自定义协议了: 合并后的strea ...

  6. arcgis新版本增加的功能

    1.导出拓扑错误 2.应用图层的符号设置 3.创建 SQLite 数据库 4.最小包围体 5.图形缓冲 6.按属性分割

  7. Android事件分发机制源码分析

    Android事件分发机制源码分析 Android事件分发机制源码分析 Part1事件来源以及传递顺序 Activity分发事件源码 PhoneWindow分发事件源码 小结 Part2ViewGro ...

  8. Google Ads原理

    Google AdSense广告会根据访问者的地理IP,显示不同的广告,因为adwords里面有相应的设置,有些广告商只想把广告显示给某一地理区域的客户.另一方面就是同一个网站,你在日本和美国会看到日 ...

  9. 局部敏感哈希 Kernelized Locality-Sensitive Hashing Page

    Kernelized Locality-Sensitive Hashing Page   Brian Kulis (1) and Kristen Grauman (2)(1) UC Berkeley ...

  10. 【BZOJ】【3083】遥远的国度

    树链剖分/dfs序 其实过了[BZOJ][4034][HAOI2015]T2以后就好搞了…… 链修改+子树查询+换根 其实静态树的换根直接树链剖分就可以搞了…… 因为其实只有一样变了:子树 如果roo ...