引言
进程是相互独立的,每个进程都有自己的虚拟地址空间,虚拟地址空间通过页表的映射,映射到自己的物理内存上,互不影响。正因为如此,进程间通信就变得很麻烦,操作系统为了使进程间能够通信,会提供一个介质,让多个进程都能够访问,也就是在内存上开辟一块公共资源,让进程在公共资源上交流。
进程间通信
在Linux系统中,有时候需要多个进程之间相互协作,共同完成某项任务,进程之间或线程之间有时候需要传递信息,有时候需要同步协调彼此工作,则就会出现进程间通信。
信号也是进程间通信的一种机制,一个进程向另一个进程发送信号,但传送的信息只限于一个信号值。因此我们将介绍以下管道,通过它进程之间可以交换更有用的数据。
管道通信
管道可以用来两个进程之间传递数据,如ps -ef|grep “bash”,其中| 就是管道,作用就是将ps命令的结果写入管道文件,然后grep在从管道文件中读出该数据进行过滤。也就是连接一个读进程和一个写进程,以实现他们通信的一个共享文件。
**管道特性:不能能在创建时就确定确定数据流向(操作系统无法确定谁读谁写),而是在使用的时候确定,因此操作系统会提供两个描述符供使用,一个读一个写,这样的确定方向就是将对应的一段关闭掉即可,这样方向的控制权就交给了用户。
有名管道
概念
在文件系统目录中存在一个管道文件,它也仅仅是文件系统中的一个标识,并没有在磁盘上占据空间,在使用的时候在内存上开辟空间,作为两个进程数据交互的通道。
创建和打开
1、命令创建:
mkfifo filename
2、通过mkfifo函数,在代码中创建管道文件
#include<sys/type.h>
#include<sys/stat.h>
int mkfifo(const char* filename,mode_t mode)
第一个参数代表路径,第二个参数代表权限值。
通信原理
以只写方式打开,写端,
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<string.h>
#include<assert.h>
#include<fcntl.h>
int main()
{
int fd = open("fifo",O_WRONLY);
assert(fd != -1);
printf("fd:%d\n",fd);
while(1)
{
char buff[128] = {
0};
printf("input:\n");
fgets(buff,128,stdin);
if