第13课-无名管道通讯编程

13.1 核心理论

1. 进程通讯方式

l  Linux作为一个多进程的操作系统,进程和进程之间是否也需要通讯呢?答案当然是需要的。我们先来看看通讯的目的:

(1)数据传输

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

(2)资源共享

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

(3)通知事件

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

(4)进程控制

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

l  Linux进程通信(IPC:interprocess communication)由以下几部分发展而来:

(1)UNIX进程间通信

(2)基于System V进程间通信

(3)POSIX进程间通信

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

下面介绍7种Linux进程间通讯的主要方式(常作为考试题,得背下来至少5):

(1)无名管道(pipe):数据传输

(2)有名管道(FIFO):数据传输

(3)信号(signal):事件通知

(4)消息队列

(5)共享内存:资源共享

(6)信号量

(7)套接字(socket)

2. 管道通讯

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

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

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

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

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

(5)管道容量为64KB(#define PIPE_BUFFERS 16 include/linux/pipe_fs_i.h)。

3. 无名管道

在Linux系统中,无名管道一旦创建完成后,操作无名管道等同于操作文件。无名管道的读端被视作一个文件;无名管道的写端也被视作一个文件。在我们使用无名管道的时候,我们首先要创建一个无名管道 , 之后的问题就是操作无名管道(读和写),当无名管道的读端和写端一旦被创建就会生成相应的两个文件。我们现在对无名管道的操作具变成了对文件的操作。

13.1 函数学习---创建无名管道

(1) 函数名

pipe

(2) 函数原形

int pipe(int pipefd[2]);

(3) 函数功能

创建一个无名管道(creats a pipe,a unidirectional单向的 data channel that can be used for interprocess communication)

(4) 所属头文件

#include<unistd.h>

(5) 返回值

成功:0

失败:-1

(6) 参数说明

pipefd[0]:管道的读端

pipefd[1]:管道的写端

l  在linux系统中,无名管道一旦创建完成后,操作无名管道就等同于操作文件。因此使用read,write,close等函数来访问无名管道。

13.3 范例程序

创建无名管道,并用于父子进程通讯。创建管道要在fork()之前创建,否则它就只属于父进程。

#include<unistd.h>

#include<sys/types.h>

#include<sys/wait.h>

#include<stdio.h>

void main()

{

pid_t pid;

int pipefd[2];

char c_buf[10];

/*  1.创建管道  */

pipe(pipefd);

/*  2.创建子进程 */

pid = fork();

if(pid>0)

{

//父进程写入数据

write(pipefd[1],"hello",6);

wait(NULL);

close(pipefd[1]);

exit(0);

}

if(pid==0)

{

//子进程读取数据

read(pipefd[0],c_buf,6) ;

printf("chlid read is %s\n",c_buf);

close(pipefd[0]);

exit(0);

}

}

运行结果:child read is hello

转载于:https://www.cnblogs.com/free-1122/p/11346072.html

第三季-第13课-无名管道通讯编程相关推荐

  1. 13.无名管道通讯编程

    13.无名管道通讯编程 1.进程间的通信: Linux作为典型的多进程操作系统,进程与进程之间肯定需要信息交流,这就需要进程通信. 2.进程通信的目的: 1.数据传输:一个进程需要将数据发送给另一个进 ...

  2. [国嵌攻略][080][无名管道通讯]

    通讯目的 1.数据传输 一个进程需要将数据发送给另外一个进程. 2.资源共享 多个进程之间共享同样的资源. 3.通知事件 一个进程需要向另外一个/组进程发送消息,通知它们发生了某事件. 4.进程控制 ...

  3. Linux系统编程- 无名管道(匿名管道)

    无名管道作为Linux进程间通讯,我们这里把理论和实际结合起来说明. 1.什么是管道 管道,英文位pipe,在学习linux系统编程一个重要概念.它的发明人是道格拉斯.麦克罗伊,这位也是UNIX上早期 ...

  4. UNIX环境高级编程——无名管道和有名管道

    一.进程间通信 每个进程各自有不同的用户地址空间,任何一个进程的全局变量在另一个进程中都看不到,所以进程之间要交换数据必须通过内核,在内核中开辟一块缓冲区,进程1把数据从用户空间拷到内核缓冲区,进程2 ...

  5. 【Linux系统编程】进程间通信之无名管道

    00. 目录 文章目录 00. 目录 01. 管道概述 02. 管道创建函数 03. 管道的特性 04. 管道设置非阻塞 05. 附录 01. 管道概述 管道也叫无名管道,它是是 UNIX 系统 IP ...

  6. 【Linux系统编程】进程间通信--无名管道(pipe)

    管道的概述 管道也叫无名管道,它是是 UNIX 系统 IPC(进程间通信) 的最古老形式,所有的 UNIX 系统都支持这种通信机制. 无名管道有如下特点: 1.半双工,数据在同一时刻只能在一个方向上流 ...

  7. linux无名管道实验代码,Linux 进程间通讯之创建无名管道和读写无名管道

    Linux进程间通讯的方式: 1. 管道(pipe)和有名管道(FIFO). 2. 信号(signal) 3. 消息队列 4. 共享内存 5. 信号量 6. 套接字(socket) 管道通讯: 无名管 ...

  8. linux进程通信1:进程通信概述,管道通信原理(无名管道,有名管道),管道编程实战

    进程通信概述,管道通信原理(无名管道,有名管道),管道编程实战 1.进程间通信概述: 举例1: 你手机微信和别人手机微信通信 举例2: 如:父子进程wait 和 exit之间的通信 进程间通信(IPC ...

  9. linux进程间通讯-无名管道

    文章目录 无名管道 无名管道的创建 -- pipe函数 无名管道的读写规律 无名管道 无名管道概述 管道(pipe)又称无名管道. 无名管道是一种特殊类型的文件,在应用层体现为两个打开的文件描述符.任 ...

  10. 嵌入式Linux系统编程学习之二十无名管道(PIPE)

      管道是 Linux 进程间通信的一种方式,如命令 ps -ef | grep ntp .   无名管道的特点包括: 只能在亲缘关系进程间通信(父子或兄弟): 半双工(固定的读端和固定的写端): 它 ...

最新文章

  1. 有哪些时间管理的习惯?
  2. Otter-入门篇4(单向同步实践)
  3. Java Optional 的 orElse() 和 orElseGet() 的区别
  4. fpga在线升级 linux_仅5000行Verilog代码、可在FPGA上跑轻量级Linux系统的RISC-V内核
  5. JMeter基础知识
  6. CentOS下搭建DNS服务器
  7. java大数 bigin_Java大数操作
  8. VS Code 调试ROS节点
  9. asp.net+sql数据库学生信息管理系统
  10. Axure RP 8制作计时器
  11. 无人机在环保行业中的应用
  12. 从零编写一个解析器(1)—— 解析数字
  13. 产品设计 【网站转化率与漏斗模型】
  14. 如何取消PPT中的动画效果
  15. 动图演示:彻底理解红黑树?
  16. mysql分区(partition)
  17. 【环境配置】python+matplotlib简单安装教程
  18. 金山软件刘鑫:有限使用UML
  19. IT项目管理 第九章 习题
  20. 送书 | 一位60后老程序员从零学习Python的感悟

热门文章

  1. Docker与容器化-01-Docker简介及Docker在CentOS7环境下安装
  2. Apache Flink 1.9 版本即将发布,新版本有哪些新特性
  3. js 栈 html标签修复,js 打印错误堆栈
  4. python快速排序函数_两种方法在Python中实现快速排序
  5. linux系统管理与服务器配置【2008网络工程师】,Linux系统管理与服务器配置
  6. gpio能测Linux启动时间,linux – 如何自动测量新建图像的启动时间...
  7. delphi ado 连接mysql_delphi mysql ado连接
  8. 计算机信息传输中枢,计算机网络综合布线及线路测试
  9. java mysql时间格式化字符串_java将日期时间字符串转成日期插入到oracle的date字段...
  10. word一键排版_这个 Word 插件神器,帮你快速搞定排版问题