首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux: linux 匿名管道

相信很多在linux平台工作的童鞋, 都很熟悉管道符 '|', 通过它, 我们能够很灵活的将几种不同的命令协同起来完成一件任务.就好像下面的命令: echo 123 | awk '{print $0+123...,则read返回0 如果所有管道端对应的文件描述符被关闭,则write操作会产生信号SIGPIPE 当要写入的数据量不大于PIPE_BUF时,linux将保证写入的原子性。...当要写入的数据量大于PIPE_BUF时,linux将不再保证写入的原子性。..., 写端会收到SIGPIPE而默认退出, 管道结束 当我们杀掉端时, 写端的程序并不会马上收到SIGPIPE, 相反的, 只有真正写入管道写端时才会触发这个错误 如果写入一个 端已经关闭的管道, 将会收到一个...SIGPIPE, 那一个写端已经关闭的管道又会这样呢?

33.9K41

Linux管道命令

1 什么是管道命令? 管道命令能够将一个命令的执行结果经过筛选,只保留我们需要的信息。...如,/etc目录下会有大量的文件,如果使用ls很难找到需要的文件,因此可以使用管道命令将ls的结果进行一次筛选,只保留需要的信息。 2 管道 和 数据流重定向 的区别?...管道一词非常生动形象,原始数据经过管道后,管道会将一部分不需要的信息过滤掉,只保留用户所关注的信息。 数据流重定向是指定数据在哪里显示,默认情况下会在屏幕显示,我们可以指定它输出到文件。...3.3.2.2 方式2:命令 | sort [-参数] 使用管道,将前一个命令执行的结果按照指定字段进行排序。...lastfile中,然后数据流将会输出到屏幕上,我们可以在输出前再添加一条管道,只输出数据的第一个字段。

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

linux——管道详解

有名管道叫named pipe或者FIFO(先进先出),可以用函数mkfifo()创建。 Linux管道的实现机制 在Linux中,管道是一种使用非常频繁的通信机制。...注意:从管道读数据是一次性操作,数据一旦被,它就从管道中被抛弃,释放空间以便写更多的数据。 1....2.管道的读写       管道实现的源代码在fs/pipe.c中,在pipe.c中有很多函数,其中有两个函数比较重要,即管道函数pipe_read()和管道写函数pipe_wrtie()。...管道写函数通过将字节复制到 VFS 索引节点指向的物理内存而写入数据,而管道函数则通过复制物理内存中的字节而读出数据。...Linux 还支持命名管道。对这些数字的早期评论员建议我,为公平起见,应该比较 Linux 的命名管道和 Windows 的命名管道。我写了另一个在 Linux 上使用命名管道的程序。

2.9K20

Linux进程通信——管道

创建匿名管道的过程 首先是父进程创建一个匿名管道。 分别以和写的方式打开同一个文件。 然后是创建子进程,子进程会继承父进程对于这个文件的读写方式。...最后一部就是让父进程关闭端,子进程关闭写端,这样就能让父进程给子进程读取数据了。 一般而言,我们管道只能用来单项数据通信。 管道就是输送资源的,就是数据。...首先来了解一下创建管道的函数; 这个函数的参数是一个输出型参数,储存的是端和写端,比如说文件描述符中,3和4是在读端和写端,那么就把3和4储存到这个数组当中。...(pipefd[0]是端,pipefd[1]是写端)这就相当于用端和写端同时打开了一个文件。...这说明如果管道没有数据了,端在读,默认会直接阻塞当前正在读取的进程,只有管道有数据,操作系统识别到,端才会去读取数据。 2. 管道是一个固定大小的缓冲区。

3.9K70

Linux管道那些事儿

管道的本质是内核维护了一块缓冲区与管道文件相关联,对管道文件的操作,被内核转换成对这块缓冲区内存的操作。...Linux下创建管道函数: int pipe(int pipefd[2]) 成功调用pipe函数之后,会返回两个打开的文件描述符,一个是管道的读取端描述符pipefd[0],另一个是管道的写入端描述符pipefd...管道没有文件名与之关联,因此程序没有选择,只能通过文件描述符来访问管道,只有那些能看到这两个文件描述符的进程才能够使用管道。如果进程执行了fork操作,那么管道就变成如下所示: ?...单向使用管道,也就是说,如果没有用到管道的进程应该尽早释放管道文件fd,这么做不仅仅是为了让数据的流向更加清晰,也不仅仅是为了节省文件描述符,更重要的原因是:关闭未使用的管道文件描述符对管道的正确使用影响重大...上面说的都是常见的管道形式,也就是匿名管道,因为没有实体文件与之关联,所以只能在具有亲属关系的进程间使用。因此就出现了另一种管道形式,命名管道,其最大的差别就是有实体文件与之关联。

2.7K50

linux 命名管道实例详解

linux进程间通信——命名管道 FIFO(命名管道)不同于匿名管道之处在于它提供⼀个路径名与之关联,以FIFO的⽂件形式存储于⽂件系统中。...命名管道是⼀个设备⽂件,因此,即使进程与创建FIFO的进程不存在亲缘关系,只要可以访问该路径,就能够通过FIFO相互通信。...值得注意的是,FIFO(first input first output)总是按照先进先出的原则⼯作,第⼀个被写⼊的数据将⾸先从管道中读出。 创建命名管道的系统函数有两个:mknod和mkfifo。...:mod为创建的命名管道的模式,指明其存取权限;dev为设备值,该值取决于⽂件创建的种类,它只在创建设备⽂件时才会⽤到。...下⾯使⽤mknod函数创建了⼀个命名管道: umask(0); if (mknod("/tmp/fifo",S_IFIFO | 0666) == -1) { perror("mkfifo error

4K21

聊聊 Linux 的匿名管道

相信很多在linux平台工作的童鞋, 都很熟悉管道符 '|', 通过它, 我们能够很灵活的将几种不同的命令协同起来完成一件任务.就好像下面的命令: echo 123 | awk '{print $0+...,则read返回0 如果所有管道端对应的文件描述符被关闭,则write操作会产生信号SIGPIPE 当要写入的数据量不大于PIPE_BUF时,linux将保证写入的原子性。...当要写入的数据量大于PIPE_BUF时,linux将不再保证写入的原子性。..., 写端会收到SIGPIPE而默认退出, 管道结束 当我们杀掉端时, 写端的程序并不会马上收到SIGPIPE, 相反的, 只有真正写入管道写端时才会触发这个错误 如果写入一个 端已经关闭的管道, 将会收到一个...SIGPIPE, 那一个写端已经关闭的管道又会这样呢?

2.6K20

Linux命名管道及函数

管道(pipe)应用的一大局限是没有名字,只能用于具有亲缘关系进程之间的通信。而命名管道,也称FIFO,实质是一种文件类型,通过FIFO可以用于任何两个进程间的通信。...命名管道的创建 命令方式 在shell中可以使用mkfifo命令创建一个命名管道,格式为: mkfifo [option] name 其中option选项用于选择创建FIFO的模式,使用形式为-m mode...函数方式 FIFO管道可通过mkfifo()函数创建,函数原型为: #include #include int mkfifo(const char...编程示例 创建一个命名管道,create_FIFO.c: #include #include #include #include...命名管道的读写 一般的文件I/O函数均可用于FIFO操作,如open、close、read、write等,若要删除一个命名管道,则使用系统调用unlink。

2.6K10

Linux - pipe() 管道的使用

初识 Pipe pipe , 中文翻译为管道,是 Unix/Linux 系统中一种比较常用的 IPC(Inter Process Communication) 。...随后,内核会返回管道端和写端的文件描述符,它们分别存放于参数数组的第 0 个元素和第 1 个元素。...管道有两端,一端为写端,另一端为端。如果一个进程试图往一个空的管道读取数据,那么该进程将会被堵塞,直至管道非空为止。.../exe child process read: hello world 管道闭环 如果子进程是负责,而父进程负责写的话。那么子进程在读之前必须关闭管道的写端,父进程同样地必须关闭管道端。...参考 [^1] 44.2 Figure 44-2, The Linux Programming Interface [^2] 44.2 Figure 44-3, The Linux Programming

8.9K00

Linux内核编程--管道pipe

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

3.6K10

Linux进程通信——有名管道

管道(pipe)是无名管道,他是进程资源的一部分,随着进程的结束而消失。并且它只能在拥有公共祖先进程的进程内通信。而有名管道(FIFO)的出现则解决了这个问题。FIFO提供了一个路径名与它关联。...总是从头开始的,写总是从尾部进行的。匿名管道和FIFO都不支持lseek函数对他们操作。Linux下建立有名管道的函数是mkfifo。...那么接着试一下直接一个FIFO文件,看看会发生什么。...管道这个名字是非常形象的,一个管道必须有两端(就是在一个进程中必须,另一个进程必须写),只有这样,才能正常操作,否则进程将会阻塞。例如下面这样。...fifo",O_WRONLY); //只写方式打开 write(fd,str,5); close(fd); return 0; } //test2的源代码 //test2是FIFO

2.7K30

Linux】进程间通信——管道

两个进程如何看到同一个管道文件:fork创建子进程完成 管道创建时分别以和写方式打开同一个文件(如果只读或者只写,子进程也只会继承只读或只写,父子双方打开文件的方式一样,无法完成单向通信);父进程创建子进程...//fork pid_t id = fork(); assert(id>=0); if(id==0) { //子进程通信:子进程进行写入,关闭...,端在读,默认会直接阻塞当前正在读取的进程 ssize_t s = read(fds[0],buffer,sizeof(buffer)-1); if(s>0) buffer...: 1.快写慢 子进程休眠时,不在写入,父进程在读取(如果管道中没有数据,端在读,此时默认会直接阻塞当前正在读取的进程) 2.慢写快 拿着管道端不读,写端一直在写:写端往管道里写,而管道是有大小的...3.写入关闭,读到0 子进程写入端关闭: 4.读取关闭,写入 管道是单向的:端关闭,在写入就没有意义了:OS会终止写端,会给写进程发送信号,终止写端 管道特征 1.管道的生命周期随进程,进程退出

16740

Linux匿名管道及实例

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

2.3K30

Linux之进程间通信——管道

前言 管道Linux中最古老的进程间通信的方式,本文介绍了进程间通信的相关概念,主要介绍了匿名管道和命名管道。 一、进程间通信 1.概念 什么是进程间通信?...fork创建子进程,管道创建时,要分别以和写的方式打开同一个文件(如果父进程是以只读或只写的方式(其中一种方式)打开文件,子进程也只会继承只读或者只写,父子双方打开文件的方式一样,导致无法完成单向通信...assert(n == id); 45 close(fds[0]);//退出程序前,关闭读取端 46 return 0; 47 } 读写特征 快...,写慢 子进程休眠时,不再写入,父进程仍在读取(如果管道内没有数据,而端在读取,则会默认直接阻塞当前正在读取的进程); 1 #include 2 #include<unistd.h...本文作者目前也是正在学习Linux相关的知识,如果文章中的内有错误或者不严谨的部分,欢迎大家在评论区指出,也欢迎大家在评论区提问、交流。

22431
领券