美文网首页
IPC之管道概述

IPC之管道概述

作者: wangxn | 来源:发表于2016-05-24 16:43 被阅读0次

管道提供了简单的流控制机制

  • 在传统的实现中, 管道是单向的,先入先出的,无结构的,固定大小的数据流.写进程是在管道的尾端写入,读进程是在管道的首端读出数据.
  • 数据读出后,将从管道移走,其他读进程不能再读取这些数据.
  • 系统调用pipe生成一个管道并返回两个描述符,一个用来读取管道,一个用来写管道.
  • 通常管道被两个进程共享, 每个进程拥有管道的一端.对管道的IO操作和对文件的IO操作非常类似.通过对管道描述符调用readwrite系统调用来操作.进程通常不知道它正在读或者写的实际上是管道.

管道的局限性

  • 管道不能用来对多个接收者广播数据
  • 管道中的数据被当作字节流,因此不好识别信息的边界.
  • 有多个写进程时,没有办法可以判断是它们那个发送的数据.

管道的实现原理(非命名管道)

  • 在Linux中,管道是通过两个file数据结构来实现的, 这两个结构指向同一个临时VFS的i节点.这个i节点指向内存中的一个物理页面.这两个file结构分别属于写入和读出进程,一个用来写,一个用来读.当写进程向管道中写数据时,这些数据会被复制到共享数据页面中,当读进程从管道中读数据时,数据从共享数据页面中复制出来.另外,Linux必须同步对管道的访问,它必须保证对管道的读写按次序完成,就是首先写进程向管道中写入数据,然后读进程从管道中读取数据.非命名管道的生命周期就是读/写进程进行管道操作的时间,它是一个临时的对象.

命名管道

  • 命名管道也叫FIFOs,因为管道的操作原则是First in, First out. 第一个向管道中写入的数据同样将是第一个从管道中读取的数据.但是, FIFOs不是一个临时的对象,它们是文件系统中的一个实体,可以通过mkfifo命令来创建.非命名管道是临时对象,在使用前必须创建它,而FIFO是一个已经存在的对象,所以只要打开并使用它就可以了.在使用命名管道时,LInux必须首先处理读进程的打开操作,然后在处理写进程的打开操作.同样,Linux首先处理读进程的读操作,然后处理写进程的写操作.

相关文章

  • IPC之管道概述

    管道提供了简单的流控制机制 在传统的实现中, 管道是单向的,先入先出的,无结构的,固定大小的数据流.写进程是在管道...

  • Android Binder进程间通信机制

    1、概述 Linux传统IPC机制主要有已下几种:管道、消息队列、共享内存Socket等。消息队列和管道采用存储-...

  • 深入浅出Binder进程间通信机制

    1、概述 Linux传统IPC机制主要有已下几种:管道、消息队列、共享内存Socket等。消息队列和管道采用存储-...

  • IPC之管道

    一般,进程之间交换信息的方法只能是经由fork或exec传送打开文件,或者通过文件系统。而进程间相互通信还有其他技...

  • 内网渗透-IPC$横向控制OA系统【网络安全】

    IPC$介绍 IPC(Internet ProcessConnection)共享“命名管道”的资源,是为了实现进程...

  • IPC概述

    进程间通信:传统上该术语描述的是运行在某个操作系统之上的不同进程名间的各种消息传递的方式。 进程间通信的目的:数据...

  • linux进程通讯(涉及Android)

    ipc(InterProcess Communication)类别 1)管道(pipe):管道是一种半双工的通信方...

  • Android进程间通信

    3.5 Android进程间通信 3.5.1 背景知识 传统IPC Linux传统的IPC机制分为如下几种:管道、...

  • Linux下进程通信 匿名管道pipe

    匿名管道(pipe): 匿名管道(pipe)是Linux支持的最初Unix IPC形式之一 匿名管道进行父子进程之...

  • Linux系统编程—管道

    ▋****1. 管道的概念 管道,又名「无名管理」,或「匿名管道」,管道是一种非常基本,也是使用非常频繁的IPC方...

网友评论

      本文标题:IPC之管道概述

      本文链接:https://www.haomeiwen.com/subject/bgbarttx.html