一起talk C栗子吧(第八十七回:C语言实例--使用管道进行进程间通信概述)


各位看官们,大家好。上一回中咱们说的是进程间通信的样例。这一回咱们说的样例是:使用管道进行进程间通信

闲话休提,言归正转。

让我们一起talk C栗子吧!

我们在前面的的章回中介绍了使用管道进行进程问的通信,时间不长,相信大家还记得。今天。我们介绍第二种进程间通信的方式:管道。大家都知道,我们使用信号在进程间通信时,本质上发送的是一个数值,假设想在进程之间发送一些数据时信号就无能为力了。此时,管道就派上了用场。

我们能够通过管道在进程之间发送数据

接下来我们就具体介绍一下管道。

管道相似我们生活中的自来水管,它能够把自来水引入到家中。在Linux命令中也有管道的身影。通常使用”|”来表示管道。我们举一个Linux命令中使用管道的样例:

 env | grep bash     //在终端中输入下面命令而且 执行
SHELL=/bin/bash      //命令执行的结果

我们在上面 的样例中首先使用env输出环境变量,然后通过管道把env命令输出的内容当作grep命令的输入内容。grep命令在输入内容中检索到了bash,并显示检索的结果。也就是我们看到的命令执行结果。

我们在进程中使用的管道和上面样例中使用的管道是相似的:在一个进程内输入数据,在另外一个进程内输出数据。

两个进程通过管道来发送数据。

我们会介绍三种管道及其用法

  • 第一种管道我称之为伪管道。
  • 第二种管道我称之为入门级管道。
  • 第三种管道是真正意义上的管道。

伪管道使用popen/pclose打开一个文件流,然后使用I/O函数对流进行操作。

由于popen的參数是某个Linux命令。而且它是通过启动shell来执行Linux命令。所以性能较低。它的效果和终端中管道命令“|”的效果同样。这也是我称其为伪管道的原因。

入门级管道通过pipe创建一个管道,而且返回两个文件描写叙述符。然后使用read/write系统调用对返回的fd进行操作,进而实现进程通信功能。该方法须要配合fork函数一起使用。由于两个fd在同一个数组中,大部分数组是局部变量。局部变量仅仅能在fork创建的父子进程中使用。

当然了,假设把fd数组定义成全局变量也能够。只是全局变量的风险就太大了。

真正意义上的管道须要使用mkfifo创建一个管道文件,它会返回一个fd。接下来,能够使用open/read等系统调用操作fd。我们能够像正常操作文件一样操作该管道文件。该管道还有另外一个名字:命名管道(FIFO)。

看官们,咱们今天仅仅对管道做一个主要的概述。至于怎样使用管道,我们会在后面的章回中具体介绍。

与此同一时候,我们也会介绍怎样使用管道在进程之间通信。

各位看官,关于使用管道进行进程间通信的样例咱们就讲到这里。欲知后面还有什么样例,且听下回分解 。


原文地址:https://www.cnblogs.com/wzjhoutai/p/7264742.html