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