管道通信

一、通讯目的

1、数据传输

  一个进程需要将数据发送给另一个进程。

2、资源共享

  多个进程之间共享同样的资源。

3、通知事件

  一个进程需要向另一个/组进程发送消息,通知它们发生了某事件。

4、进程控制

  有些进程希望完全控制另一个进程的执行(如Debug进程),此时控制进程希望能够拦截另一个进程的所有操作,并能够及时知道它的状态改变。

二、通讯发展

Linux进程间通信(IPC:interprocesscommunication)由以下几部分发展而来:

  1、UNIX进程间通信

  2、基于System V进程间通信

  3、POSIX进程间通信

  POSIX(Portable Operating System Interface)表示可移植操作系统接口。电气和电子工程师协会IEEE最初开发POSIX 标准,是为了提高UNIX 环境下应用程序的可移植性。然而,POSIX 并不局限于UNIX,许多其它的操作系统,例如Microsoft Windows都支持POSIX 标准。

三、通讯方式

Linux进程间通讯的主要方式有:

  1、无名管道(pipe)

  2、有名管道(FIFO)

  3、信号(signal)

  4、消息队列

  5、共享内存

  6、信号量

  7、套接字(socket)

四、管道通信

一个进程在管道的尾部写入数据,另一个进程从管道的头部读出数据。管道包括无名管道和有名管道两种,前者只能用于父进程和子进程间的通信,后者可用于运行于同一系统中的任意两个进程间的通信。

管道通信特点:

  1.管道通讯是单向的,有固定的读端和写端。

  2.数据被进程从管道读出后,在管道中该数据就不存在了。

  3.当进程去读取空管道的时候,进程会阻塞。

  4.当进程往满管道写入数据时,进程会阻塞。

  5.管道容量为64KB(#definePIPE_BUFFERS16 include/linux/pipe_fs_i.h)

  在Linux系统中,无名管道一旦创建完成后,操作无名管道等同于操作文件。无名管道的读端被视作一个文件;无名管道的写端也被视作一个文件。

五、无名管道函数学习pipe

5.1 函数原形

  int pipe(int pipefd[2]);

5.2函数功能

  创建无名管道

5.3 所属头文件

  <unistd.h>

5.4 返回值

  成功:返回 0

  失败:返回-1

5.5 参数说明

  pipefd[2]返回两个文件描述符,两个元素分别指向两端

  pipefd[0]:指向管道读端

  pipefd[1]:指向管道写端

六、有名管道

  有名管道又称为FIFO文件,因此我们对有名管道的操作可以采用操作文件的方法,如使用open,read,write等.

6.1FIFO文件对比普通文件

FIFO文件在使用上和普通文件有相似之处,但是也有不同之处:

  1.读取Fifo文件的进程只能以”RDONLY”方式打开fifo文件。

  2.写Fifo文件的进程只能以”WRONLY”方式打开fifo文件。

  3.Fifo文件里面的内容被读取后,就消失了。但是普通文件里面的内容读取后还存在。

当执行写fifo文件后则进程一直处于阻塞状态直到有进程去读取管道中的文件

6.2 创建有名管道

6.2.1 函数名

  mkfifo

6.2.2 函数原形

  int mkfifo(const char* pathname,mode_t mode);

6.2.3 函数功能

  创建fifo文件(有名管道)

6.2.4 所属头文件

  <sys/types.h>   <sys/stat.h>

6.2.5 返回值

  成功:返回 0

  失败:返回-1

6.2.6 参数说明

  pathname:要创建的fifo文件的名字(包含路径)

  mode:标明白创建fifo文件访问权限

6.3 删除有名管道

6.3.1 函数名

  unlink

6.3.2 函数原形

  int unlink(const char* pathname);

6.3.3 函数功能

  删除文件,包含fifo文件

6.3.4 所属头文件

  <unistd.h>

6.3.5 返回值

  成功:返回0

  失败:返回-1

6.3.6 参数说明

  指定要删除文件的名称(包含路径)

管道通信,王明学learn的更多相关文章

  1. 消息队列通信,王明学learn

    消息队列通信 消息队列就是一个消息(一个结构)的链表.而一条消息则可看作一个记录,具有特定的格式.进程可以从中按照一定的规则添加新消息:另一些进程则可以从消息队列中读走消息. 每一个消息都是一个结构体 ...

  2. linux内核的组成,王明学learn

    linux内核的组成 一.linux内核源代码目录结构 arch: 包含和硬件体系结构相关的代码, 每种平台占一个相应的目录, 如 i386.ARM.PowerPC.MIPS 等. block:块设备 ...

  3. 共享内存同行,王明学learn

    共享内存同行 一.共享内存概念 共享内存是IPC机制中的一种,它允许两个不相关的进程访问同一段内存, 这是传递数据的一种非常有效的方式. 二.函数学习 这里主要有创建共享内存.映射共享内存.分离共享内 ...

  4. linux驱动程序设计的硬件基础,王明学learn

    linux驱动程序设计的硬件基础(一) 本章讲总结学习linux设备程序设计的硬件基础. 一.处理器 1.1通用处理器 通用处理器(GPP)并不针对特定的应用领域进行体系结构和指令集的优化,它们具有一 ...

  5. linux设备驱动概述,王明学learn

    linux设备驱动学习-1 本章节主要学习有操作系统的设备驱动和无操作系统设备驱动的区别,以及对操作系统和设备驱动关系的认识. 一.设备驱动的作用 对设备驱动最通俗的解释就是“驱使硬件设备行动” .设 ...

  6. usb设备驱动描述,王明学learn

    usb设备驱动 本章主要内容包含以下:USB总线介绍,USB协议分析,USB系统架构 一.USB总线介绍 1.1USB发展史 USB(Universal Serial Bus)通用串行总线,是一种外部 ...

  7. 信号量进程同步,王明学learn

    信号量进程同步 一组并发进程进行互相合作.互相等待,使得各进程按一定的顺序执行的过程称为进程间的同步. 信号量在进程同步时初始值为:0 信号量在进程互斥时初始值为:大于0的 本章节主要使用信号量,使的 ...

  8. 信号量互斥,王明学learn

    信号量互斥 信号量(又名:信号灯)与其他进程间通信方式不大相同,主要用途是保护临界资源(进程互斥).进程可以根据它判定是否能够访问某些共享资源.除了用于访问控制外,还可用于进程同步. 一.信号量分类 ...

  9. 信号通讯编程,王明学learn

    信号通讯编程 在Linux系统中,信号(signal)同样也是最为古老的进程间通信机制. 一.信号类型 Linux系统支持的所有信号均定义在/usr/include/asm/signal.h(展示), ...

随机推荐

  1. Java文件读写操作指定编码方式防乱码

    读文件:BufferedReader 从字符输入流中读取文本,缓冲各个字符,从而提供字符.数组和行的高效读取. 可以指定缓冲区的大小,或者可使用默认的大小.大多数情况下,默认值就足够大了. 通常,Re ...

  2. git cherry-pick简介

    本文编辑整理自: http://sg552.iteye.com/blog/1300713 http://web.mit.edu/bitbucket/git-doc/git-cherry-pick.tx ...

  3. C#之Textbox实现自动提示容、自动补齐内容

    今发现一个博文挺有意思,实现的功能很有意思但方法却很简单,特此转过来,以备以后查阅. 先上原博文地址:http://blog.csdn.net/testcs_dn/article/details/45 ...

  4. ios coredata NSManagedObject 的 objectID

    要使用这个属性一定要注意先把数据保存下,不然会变化的!就无法通过 - (NSManagedObject*)existingObjectWithID:(NSManagedObjectID*)object ...

  5. java 入门 第二季3

    1.继承 1.java是单继承的,一个子类只有一个父类 父类,基类 子类,派生类 2.继承的好处:子类拥有父类的所有属性和方法,属性的修饰符不能是private 3.语法规则: class 子类 ex ...

  6. Mathematics:Dead Fraction(POJ 1930)

    消失了的分式 题目大意:某个人在赶论文,需要把里面有些写成小数的数字化为分式,这些小数是无限循环小数(有理数),要你找对应的分母最小的那个分式(也就是从哪里开始循环并不知道). 一开始我也是蒙了,这尼 ...

  7. 【leetcode】Merge Two Sorted Lists(easy)

    Merge two sorted linked lists and return it as a new list. The new list should be made by splicing t ...

  8. (2016弱校联盟十一专场10.2) A.Nearest Neighbor Search

    题目链接 水题,算一下就行. #include <bits/stdc++.h> using namespace std; typedef long long ll; ll x[],y[], ...

  9. CCF I'm Stuck!

    问题描述 试题编号: 201312-5 试题名称: I'm stuck! 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给定一个R行C列的地图,地图的每一个方格可能是'#', ...

  10. JS不用通过其他转换两个小数加减得到正确答案

    之前写过一篇文章js比较两个属于float类型的小数,都需要通过某种函数转换下,太麻烦了,比如: 减法:10.2345-0.01=10.2245,这是正确的答案,但是当你做加法的时候就变了 加法:10 ...