各位看官们,大家好,上一回中咱们说的是进程间通信的例子,这一回咱们说的例子是:使用管道进行进程间通信。闲话休提,言归正转。让我们一起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)。
看官们,咱们今天只对管道做一个基本的概述,至于如何使用管道,我们会在后面的章回中详细介绍。与此同时,我们也会介绍如何使用管道在进程之间通信。
各位看官,关于使用管道进行进程间通信的例子咱们就说到这里。欲知后面还有什么例子,且听下回分解 。