首页
学习
活动
专区
工具
TVP
发布

Linux】命名管道的创建方法&&基于命名管道两个进程通信的实现

一、匿名管道和命名管道的区别 匿名管道由pipe函数创建并打开。...命名管道由mkfifo函数创建,打开用open FIFO(命名管道)与pipe(匿名管道)之间唯一的区别在它们创建与打开的方式不同,一但这些工作完成之后,它们具有相同的语义。...); pathname指创建出来的管道的路径和管道名,mode指创建出来的管道的权限,这里的权限和文件的权限是一样的。...二、删除命名管道的函数 #include // 返回值:成功返回0,出错返回-1 int unlink(const char *pathname); pathname指创建出来的管道的路径和管道名...三、利用命名管道实现两个进程之间的简单通信  这个通信将实现写端发送信息读端接收信息。更多地实现细节会在代码中以注释的方式给出。

3710

Linux: linux 匿名管道

相信很多在linux平台工作的童鞋, 都很熟悉管道符 '|', 通过它, 我们能够很灵活的将几种不同的命令协同起来完成一件任务.就好像下面的命令: echo 123 | awk '{print $0+123...当管道被放满信息的时候,尝试放入信息的进程会堵塞,直到另一端的进程取出信息。当两个进程都终结的时候,管道也自动消失。 管道工作流程图 ?...,则read返回0 如果所有管道读端对应的文件描述符被关闭,则write操作会产生信号SIGPIPE 当要写入的数据量不大于PIPE_BUF时,linux将保证写入的原子性。...当要写入的数据量大于PIPE_BUF时,linux将不再保证写入的原子性。..."1", line 6, in sys.stdout.flush() IOError: [Errno 32] Broken pipe Terminated 从上图我们可以验证两个

33.9K41
您找到你想要的搜索结果了吗?
是的
没有找到

Linux管道命令

1 什么是管道命令? 管道命令能够将一个命令的执行结果经过筛选,只保留我们需要的信息。...管道一词非常生动形象,原始数据经过管道后,管道会将一部分不需要的信息过滤掉,只保留用户所关注的信息。 数据流重定向是指定数据在哪里显示,默认情况下会在屏幕显示,我们可以指定它输出到文件。...3.7 连接两个文件:join 3.7.1 join命令介绍 这个命令与管道无关。 它相当于数据库中的join连接,将两张表中指定字段,且字段相同的行连接起来。...在这里,它能够将两个文件中指定字段的相同字段连接起来,并成一行。...3.7.2 join命令的用法 join [-参数] 文件1 文件2 -t:两个文件的字段分隔符 -1:第一个文件的字段 -2:第二个文件的字段 -i:忽略选取字段的大小写 3.8 切割文件:split

4.4K70

linux——管道详解

有名管道叫named pipe或者FIFO(先进先出),可以用函数mkfifo()创建。 Linux管道的实现机制 在Linux中,管道是一种使用非常频繁的通信机制。...从本质上说,管道也是一种文件,但它又和一般的文件有所不同,管道可以克服使用文件进行通信的两个问题,具体表现为: 限制管道的大小。实际上,管道是一个固定大小的缓冲区。...通过将两个 file 结构指向同一个临时的 VFS 索引节点,而这个 VFS 索引节点又指向一个物理页面而实现的。...2.管道的读写       管道实现的源代码在fs/pipe.c中,在pipe.c中有很多函数,其中有两个函数比较重要,即管道读函数pipe_read()和管道写函数pipe_wrtie()。...Linux 还支持命名管道。对这些数字的早期评论员建议我,为公平起见,应该比较 Linux 的命名管道和 Windows 的命名管道。我写了另一个在 Linux 上使用命名管道的程序。

2.9K20

Linux进程通信——管道

管道 进程通信概念 管道 匿名管道 创建匿名管道的过程 管道读写的特性 管道本身的特征 基于管道的进程池设计 命名管道两个无血缘关系的进程通信 进程通信概念 什么是进程通信 首先我们清楚,进程是具有独立性的...我们把从一个进程连接到另一个进程的一个数据流称为一个“管道”。 管道是基于文件系统的。 那么两个进程通信: 第一个条件就是操作系统需要给双方进程提供内存空间。...那么我们如何让两个进程看到同一个管道文件呢? 首先清除fork是创建子进程的,子进程会继承父进程的文件地址,这样就能看到同一份管道文件了,但是这个文件并没有名字,所以叫做匿名管道。...命名管道 这个管道可用于两个没有血缘关系的进程进行通信。 第一个参数是文件路径+文件名,第二个参数是权限(和创建文件的权限是一个东西)。 成功返回0,失败返回-1....让两个无血缘关系的进程通信 首先让两个进程打开指定名称(路径+文件名)的同一个文件。

3.9K70

Linux管道那些事儿

管道实质是一个字节流,并非前面提到的消息,没有消息的边界。如果多个进程发送的字节流混在一起,则无法辨认出各自的内容。所以一般是两个有亲缘关系的进程用管道来通信。...管道的本质是内核维护了一块缓冲区与管道文件相关联,对管道文件的操作,被内核转换成对这块缓冲区内存的操作。...Linux下创建管道函数: int pipe(int pipefd[2]) 成功调用pipe函数之后,会返回两个打开的文件描述符,一个是管道的读取端描述符pipefd[0],另一个是管道的写入端描述符pipefd...管道没有文件名与之关联,因此程序没有选择,只能通过文件描述符来访问管道,只有那些能看到这两个文件描述符的进程才能够使用管道。如果进程执行了fork操作,那么管道就变成如下所示: ?...在shell中执行管道命令就是这种情景,只是略有特殊之处,其特殊的地方是管道描述符占用了标准输入和标准输出两个文件描述符。

2.7K50

Linux进程通信 管道

(2)管道只能在具有公共祖先的两个进程之间使用。通常,一个管道由一个进程创建,在进程调用fork后,这个管道就能在父进程和子进程之间使用了。(FIFO无此局限)。       ...--《Unix环境高级编程》 通俗理解: Linux管道通信,通讯方式正如其名一样,如同一个大管道,一端流入,一端流出。...PIPE PIPE是一种半双工管道,其中,fd[1]用来向管道写入数据,fd[0]用来从管道读出数据。若两个进程需要利用PIPE通信,就要保证一个进程使用fd[0],另一个进程使用fd[1]。...Code: //参考Linux man手册 #include #include #include #include <stdlib.h...FIFO FIFO有时也会被称为命名管道,未命名的管道(PIPE)只能在两个相关的进程间使用,而且这个两个进程还要有共同的创建了它们的祖先进程。但是,通过FIFO,不相关的进程也能进行数据交换。

3.1K10

聊聊 Linux 的匿名管道

相信很多在linux平台工作的童鞋, 都很熟悉管道符 '|', 通过它, 我们能够很灵活的将几种不同的命令协同起来完成一件任务.就好像下面的命令: echo 123 | awk '{print $0+...当管道被放满信息的时候,尝试放入信息的进程会堵塞,直到另一端的进程取出信息。当两个进程都终结的时候,管道也自动消失。 管道工作流程图 ?...,则read返回0 如果所有管道读端对应的文件描述符被关闭,则write操作会产生信号SIGPIPE 当要写入的数据量不大于PIPE_BUF时,linux将保证写入的原子性。...当要写入的数据量大于PIPE_BUF时,linux将不再保证写入的原子性。..."1", line 6, in sys.stdout.flush() IOError: [Errno 32] Broken pipe Terminated 从上图我们可以验证两个

2.6K20

Linux命名管道及函数

管道(pipe)应用的一大局限是没有名字,只能用于具有亲缘关系进程之间的通信。而命名管道,也称FIFO,实质是一种文件类型,通过FIFO可以用于任何两个进程间的通信。...命名管道的创建 命令方式 在shell中可以使用mkfifo命令创建一个命名管道,格式为: mkfifo [option] name 其中option选项用于选择创建FIFO的模式,使用形式为-m mode...命名管道的读写 一般的文件I/O函数均可用于FIFO操作,如open、close、read、write等,若要删除一个命名管道,则使用系统调用unlink。...测试 分别编译上述两个程序。...测试之前先使用mkfifo命令创建一个名为fifo1的命名管道: mkfifo -m 666 fifo1 然后打开两个shell窗口,依次运行write_fifo和read_fifo两个程序。

2.6K10

Linux内核编程--管道pipe

管道的定义: 管道是一种进程间通信机制,也是Linux操作系统中的一种文件形式。一个进程写入管道的数据可以被另一个进程读取。数据按先进先出顺序处理。Linux有两种形式的管道文件,管道和FIFO。...管道提供一个单向的数据流【半双工管道】, 示意图: 管道和FIFO的异同: 管道没有名字,只能由“亲缘关系”的进程间进行通信时使用,例如父子进程间的通信。...管道的创建: 管道由pipe函数创建 #include int pipe(int fd[2]) --创建一个管道并将管道读写端的文件描述符(分别)放入fd[0]和fd[1] --...管道成功创建时返回0 *有些版本的操作系统可以创建全双工管道,使用socketpair函数创建 管道创建的经典场景: 一个进程在它派生一个或多个子进程之前创建一个管道, 然后将管道用于父进程和子进程之间或两个兄弟进程之间的通信...FIFO的原子性,需要对管道和FIFO加以限制: OPEN_MAX: 一个进程在任意时刻打开的最大描述符数 PIPE_BUF:可原子地写往一个管道或FIFO的最大数据量 shell脚本中的管道指令:

3.6K10

Linux - pipe() 管道的使用

初识 Pipe pipe , 中文翻译为管道,是 Unix/Linux 系统中一种比较常用的 IPC(Inter Process Communication) 。...ls | wc -l ls 和 wc 分别是两个独立的进程。shell 会将 ls 的输出结果作为 wc 的输入结果,然后再由 wc 把处理结果投放到终端上。...Pipe的读写 之所以叫 IPC, 顾名思义,管道就是用来让两个或者多个进程之间通信,尽管多个进程共享一个管道的情况十分少见,但我们并未被禁止这样做,但我们在大多数情况都绝不应该这样做。...管道有两端,一端为写端,另一端为读端。如果一个进程试图往一个空的管道读取数据,那么该进程将会被堵塞,直至管道非空为止。...参考 [^1] 44.2 Figure 44-2, The Linux Programming Interface [^2] 44.2 Figure 44-3, The Linux Programming

8.8K00

Linux匿名管道及实例

匿名管道,也称管道,是Linux下最常见的进程间通信方式之一。匿名管道在系统中没有实名,它只是进程的一种资源,会随着进程的结束而被系统清除。...管道的创建与关闭 Linux中使用pipe()函数创建一个匿名管道,其函数原型为: #include int pipe(int fd[2]); 创建成功返回0,出错返回1。...进程间管道的读写 单独对一个进程进行管道的读写是没有实际意义的,管道的应用体现在父子进程或兄弟进程之间的通信。...上述程序中父进程分别建立了两个子进程,在子进程1中关闭了管道的读出端,在子进程2中关闭了管道的输入端,并在父进程中关闭了管道的两端,从而构成了从子进程1到子进程2的管道。...参考:《精通Linux C编程》- 程国钢 附:fork()函数的使用示例,参考:https://blog.csdn.net/jason314/article/details/5640969 #include

2.3K30

Linux进程通信——有名管道

管道(pipe)是无名管道,他是进程资源的一部分,随着进程的结束而消失。并且它只能在拥有公共祖先进程的进程内通信。而有名管道(FIFO)的出现则解决了这个问题。FIFO提供了一个路径名与它关联。...这样可以通过访问该路径就能使得两个进程之间相互通信。此处的FIFO严格遵守“先进先出”原则。读总是从头开始的,写总是从尾部进行的。匿名管道和FIFO都不支持lseek函数对他们操作。...Linux下建立有名管道的函数是mkfifo。...管道这个名字是非常形象的,一个管道必须有两端(就是在一个进程中必须读,另一个进程必须写),只有这样,才能正常操作,否则进程将会阻塞。例如下面这样。...或者说,这也体现了进程的并发行,管子有了一端以后,还必须有另一端,这才能构成管道。 测试一下,FIFO用于两个无关进程直接的通信。首先建立我们有两个进程,一个是test1,另一个是test2.

2.7K30

Linux】进程间通信——管道

2.采用文件的做法:管道-基于文件系统(匿名管道、命名管道) 而本篇博客主要介绍管道,接着往下看把 ---- 管道 2.1管道介绍 管道是Unix中最古老的进程间通信的形式。...两个进程如何看到同一个管道文件:fork创建子进程完成 管道创建时分别以读和写方式打开同一个文件(如果只读或者只写,子进程也只会继承只读或只写,父子双方打开文件的方式一样,无法完成单向通信);父进程创建子进程...让两个进程看到同一个文件,通过父进程创建子进程,子进程继承文件地址的方式,看到同一个内存级文件,此时内存级文件没有名称就是匿名管道了。匿名管道能用来父进程和子进程之间进行进程间通信。...那如果两个毫不相干的进程间通信交互呢?如果我们想在不相关的进程之间交换数据,可以使用FIFO文件来做这项工作,它经常被称为命名管道。...在当前路径下直接创建命名管道: mkfifo named_pipe 往管道文件写东西: 两个进程打开同一个文件:站在内核的角度,第二个文件不需要继续创建struct file对象,因为OS会识别到打开的文件被打开了

16040

Linux之进程间通信——管道

前言 管道Linux中最古老的进程间通信的方式,本文介绍了进程间通信的相关概念,主要介绍了匿名管道和命名管道。 一、进程间通信 1.概念 什么是进程间通信?...本文主要介绍的是管道。 二、管道 1.管道介绍 管道是Unix中最古老的进程间通信的方式,我们把连接两个进程的数据流称为“管道”。...这种方式中被子进程写入和父进程读取的文件,我们称为管道文件。管道文件本质就是内存级文件(不需要IO)。 两个进程如何看到同一个管道文件?...2.命名管道 匿名管道的限制就是只能在具有血缘关系的进程间通信,那么如果是两个毫不相干的进程间通信交互呢? 如果我们想要在两个不相关的进程之间进行通信,我们可以使用FIFO文件,它被称为命名管道。...匿名管道是通过继承的方式让两个进程看到一个文件(资源),命名管道是通过让不同的进程打开指定名称(路径+文件名)的文件,来看待同一份资源。

21431
领券