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

Java IO 之 管道流 原理分析

概述 管道流是用来在多个线程之间进行信息传递的Java流。 管道流分为字节流管道流和字符管道流。 字节管道流:PipedOutputStream 和 PipedInputStream。...java的管道输入与输出实际上使用的是一个循环缓冲数来实现的。输入流PipedInputStream从这个循环缓冲数组中读数据,输出流PipedOutputStream往这个循环缓冲数组中写入数据。...Override public void run() { try { String s = "hello world, amazing java...管道流,做开发这么多年,现在都没有遇到可用的场景。管道流能用到的场景,在并发包种,很多方式都可以实现或代替。比如 java.util.concurrent.Exchanger 类。...java.util.concurrent.Exchanger 的使用场景比管道流使用场景更广泛些。 ----

2.2K100
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    匿名管道和命名管道

    ),然后用户层缓冲区通过系统调用(write)写到管道里,然后再通过read系统调用,被对方(读端)读取,就要从管道拷贝到读端,然后再显示到显示器上。...通信是为了更好的发送变化的数据,管道本质上是文件 所以必须要用到系统调用接口来访问管道,其是由系统管理,read和write ,操作系统相当于中介 结论:管道的特征: 1:具有血缘关系的进程进行进程间通信...2:管道只能单向通信 3:父子进程是会进程协同的,同步与互斥的--保护管道文件的数据安全 4:管道是面向字节流的 5:管道是基于文件的,而文件的生命周期是随进程的 再测试,把子进程sleep去掉,就是让子进程写快一点...,父进程sleep几秒,就是让父进程读慢一点,看有什么现象 管道的四种情况 测试管道大小 把c一直往管道里写,把父进程中休眠50秒 结果差不多64kb 写端退了,测试结果 结果是: 读端正常读,写端关闭...,还得把用户层缓冲区拷贝到管道里,(从键盘里输入数据到用户层缓冲区里面),然后用户层缓冲区通过系统调用(write)写到管道里,然后再通过read系统调用,被对方(读端)读取,就要从管道拷贝到读端,然后再显示到显示器上

    68310

    【Linux】管道通信——命名管道

    命名管道 什么是命名管道 命名管道,也称为 FIFO(First In First Out),是一种 进程间通信(IPC) 机制,它允许不相关的进程(即没有父子关系的进程)通过文件系统中的特殊文件进行数据传输...命名管道 vs....无名管道 类型 说明 适用场景 匿名管道 pipe() 创建,仅限于父子进程之间通信 适用于父进程创建子进程并通信 命名管道 mkfifo() 创建,存在于文件系统中,可用于任意进程间通信 适用于独立进程间通信...如何创建命名管道 手动创建命名管道: mkfifo FIFO 这个FIFO也是一个文件,被操作系统特殊标记过,是管道文件。...,我们封装一个类,用于管理管道文件的创建和销毁,声明一个全局变量,构造函数用于创建管道,析构函数用于销毁管道,由于全局变量的生命周期是和程序一样的,所以当程序结束的时候管道文件也跟着销毁,也意味着通信结束

    1.1K10

    【Linux】IPC 进程间通信(一):管道(匿名管道&命名管道)

    父进程向以写方式打开的文件的管道文件写入,子进程再从以读方式打开的文件的管道文件读取,从而实现管道通信。如果是要子进程向父进程传输数据,同理即可。...管道里的内容不需要刷新到磁盘 2.2 创建匿名管道 匿名管道:没有名字的文件(struct file) 匿名管道用于父子间通信,或者由一个父创建的兄弟进程(必须有“血缘“)之间进行通信 #include...2.3 匿名管道通信案例(父子通信) 注意:匿名管道需要在创建子进程之前创建,因为只有这样才能复制到管道的操作句柄,与具有亲缘关系的进程实现访问同一个管道通信 情况一:管道为空 && 管道正常(read...就会阻塞 4.4 匿名管道与命名管道的区别 匿名管道与命名管道的区别 匿名管道由 pipe函数 创建并打开。...管道分为两种类型:无名管道和命名管道 无名管道主要用于具有亲缘关系的进程(如父子进程),在创建时不需要名称,只能通过文件描述符进行访问 命名管道(FIFO)则可以在任何进程之间通信,使用文件系统中的路径来标识

    1.1K10

    关于go的只读管道只写管道以及单向管道的理解

    ,只能写数据到管道里面 func writeChan(ch chan<- int) { ch <- 1 } //单向只读管道,只能从管道里面读出数据 func readChan(ch <-chan...{ value := <-ch fmt.Println(value) } 上面的例子,writeChan只能对ch变量进行写操作,readChan只能对ch变量进行读操作,这样造成很多同学对管道理解就有了只读和只写管道了...,其实管道都是双向的,默认双向可读写,只是管道在函数参数传递时可以使用操作符限制管道的读写,就如上面的例子。...关于上面单向管道的例子,单向管道只能用于发送或者接受数据,但是go的管道其实是没有单向管道,所谓的单向管道只是对管道的一种使用限制,这个和c语言const修饰函数参数为只读是一个道理。...总结: go语言是没有只读管道,只写管道,单向管道。 所谓的只读管道,只写管道,单向管道只是对go的管道一种限制使用。

    1.2K10

    Redis 管道

    Redis管道是一种通过一次发出多个命令而不等待每个单独命令的响应来提高性能的技术。大多数Redis客户端都支持管道。本文档描述了管道旨在解决的问题以及Redis中管道的工作原理。...Redis自早期以来就支持管道,因此无论您运行的是哪个版本,都可以将管道与Redis一起使用。...当使用管道时,通常使用单个read()系统调用来读取多个命令,使用单个write()系统调用来传递多个回复。...因此,每秒执行的总查询数量最初随着管道长度的增加而几乎线性增长,并最终达到未使用管道时获得的基线的10倍,如下图所示: 示例 在接下来的基准测试中,我们将使用支持管道的Redis Ruby客户端来测试由于管道而带来的速度提升...管道 vs 脚本 使用Redis脚本[2](自Redis 2.6起可用),可以通过在服务器端执行大量所需工作的脚本来更有效地解决许多管道用例。

    43810

    详解管道

    进程间通信的发展:管道System V进程间通信POSIX进程间通信管道:匿名管道pipe命名管道System V IPC:System V 消息队列System V 共享内存System V 信号量POSIX...IPC:消息队列共享内存信号量互斥量条件变量读写锁二,管道管道是Unix中最古老的进程间通信的形式。...这样通信方式我们叫做匿名管道。管道的本质是一种文件。下面我们来简单的实现一个匿名管道:使用pipe系统调用来创建匿名管道。...因此管道可以让进程间协同,提供了访问控制。管道提供的是面向流式的通信服务,其生命周期随进程。从管道读数据是一次性操作,数据一旦被读,它就从管道中被抛弃,释放空间以便写更多的数据。...:命名管道与匿名管道的原理相同,都是通过让两个进程看到同一份资源,从而实现通信,但命名管道不再局限于父子进程之间,而是任意两个进程之间实现通信。

    53651

    ​将 Logstash 管道转换为 OpenTelemetry Collector 管道

    简化的遥测管道:使用接收器、处理器和导出器构建管道的能力,通过集中数据流和减少多个代理的需求,简化了遥测管理。...Logstash 管道定义 Logstash 管道由三个主要组件组成: Input Plugins:允许我们从不同来源读取数据。 Filters Plugins:允许我们转换和过滤数据。...Logstash 还有一个特殊的输入和一个特殊的输出,允许管道到管道的通信,我们可以将其视为类似于 OpenTelemetry 连接器的概念。...Logstash 管道与 OTEL Collector 组件的比较 我们可以将 Logstash 管道和 OTEL Collector 管道组件如何相互关联进行示意化: 理论够多了!...OpenTelemetry Collector 管道来处理日志。

    59221

    进程通信(一)无名管道和有名管道

    向管道(共享文件)提供输入的发送进程(即写进程),以字符流的形式将大量的数据送入(写)管道;而接受管道输出的接受进程(即读进程),则从管道接受(读)数据。...为了协调双方的通信,管道机制必须提供一下三个方面的协调能力:互斥、同步和确定对方存在。 下面以linux的管道为例进行说明。在linux中,管道是一种频繁使用的通信机制。...从本质上讲,管道也是一种文件,但它又和一般的文件有所不同,管道可以克服使用文件通信的两个问题,具体表现为: 1)限制管道的大小。实际上,管道是一个固定大小的缓冲区。...注意 :从管道读数据是一次性操作,数据一旦被读走,它就从管道中被抛弃,释放空间以便写更多的数据。管道只能采用半双工通信,即在某一时刻只能单向传输。要实现父子进程双方互动,需要定义两个管道。...2.有名管道 由于无名管道的局限性,仅限于有血缘关系的进程间通信,所以当需要在不同进程(无血缘关系的进程)之间通信,pipe就不能被使用了。取而代之是有名管道(fifo)。

    1.9K20

    速度不够,管道来凑——Redis管道技术

    Redis客户端与服务器之间使用TCP协议进行通信,并且很早就支持管道(pipelining)技术了。在某些高并发的场景下,网络开销成了Redis速度的瓶颈,所以需要使用管道技术来实现突破。...管道技术其实已经非常成熟并且得到广泛应用了,例如POP3协议由于支持管道技术,从而显著提高了从服务器下载邮件的速度。...在Redis中,如果客户端使用管道发送了多条命令,那么服务器就会将多条命令放入一个队列中,这一操作会消耗一定的内存,所以管道中命令的数量并不是越大越好(太大容易撑爆内存),而是应该有一个合理的值。...使用管道时,多个命令只会进行一次read()和wrtie()系统调用,因此使用管道会提升Redis服务器处理命令的速度,随着管道中命令的增多,服务器每秒处理请求的数量会线性增长,最后会趋近于不使用管道的...下面就来对比一下使用管道和不使用管道的速度差异。

    1.5K30

    【Linux进程#1】IPC 进程间通信(一):管道(匿名管道&命名管道)

    2.3 匿名管道通信案例(父子通信) 注意:匿名管道需要在创建子进程之前创建,因为只有这样才能复制到管道的操作句柄,与具有亲缘关系的进程实现访问同一个管道通信 情况一:管道为空(父进程) && 管道正常...就会阻塞 4.4 匿名管道与命名管道的区别 匿名管道与命名管道的区别 匿名管道由 pipe函数 创建并打开。...对于命名管道(FIFO),unlink 可以用于删除命名管道文件。删除命名管道后,文件系统中的路径名将不再存在,但已经打开命名管道的进程仍然可以继续使用它,直到所有进程都关闭它。...释放资源 删除命名管道后,文件系统会释放与该文件相关的资源。 不影响已打开的管道 如果命名管道已经被某些进程打开,unlink 不会立即关闭这些管道。...管道分为两种类型:无名管道 和 命名管道 无名管道主要用于具有亲缘关系的进程(如父子进程),在创建时不需要名称,只能通过文件描述符进行访问 命名管道(FIFO)则可以在任何进程之间通信,使用文件系统中的路径来标识

    49410

    【Java 基础篇】深入理解 Java 管道(Pipes):从基础到高级

    Java 管道正是为此而设计的。 Java 管道允许一个 Java 进程中的线程与另一个 Java 进程中的线程进行通信。这种通信方式非常强大,可用于各种场景,例如数据传输、任务协作等。...在接下来的内容中,我们将学习如何使用 Java 管道来满足不同的通信需求。 2. 什么是 Java 管道? Java 管道是一种特殊的流,用于在线程之间传递数据。...基础用法 让我们从 Java 管道的基础用法开始,以便理解其工作原理。 3.1 创建管道 要使用 Java 管道,首先需要创建一个管道。...高级用法 除了基础用法外,Java 管道还支持一些高级用法,可以满足更复杂的通信需求。 4.1 管道缓冲区 默认情况下,Java 管道没有内置的缓冲区,这意味着数据会立即从输出管道流传输到输入管道流。...5.4 管道的异常处理 在Java中,管道的使用可能会涉及到异常处理。

    1.4K20

    【进程间通信】IPC、管道pipe、命名管道FIFO

    二、pipe管道 1. 什么是管道 管道是一种最基本的IPC机制,作用于有血缘关系的进程之间,完成数据传递。调用pipe()系统函数就可以创建一个管道。...③ 如果父进程关闭管道读端,子进程关闭管道写端,此时父进程可以向管道中写入数据,子进程将管道中的数据读出,反之同理。...如果有指向管道写端的文件描述符没关闭(管道写端引用计数大于0),而持有管道写端的进程也没有向管道中写数据,这时有进程从管道读端读数据,那么管道中剩余的数据都被读取后,再次read会阻塞,直到管道中有数据可读了才读取数据并返回...(在讲信号的时候会细说) 如果有指向管道读端的文件描述符没关闭(管道读端引用计数大于0),而持有管道读端的进程也没有从管道中读数据,这时有进程向管道写端写数据,那么在管道被写满时再次write会阻塞,直到管道中有空位置了才写入数据并返回...其实,总的来说可以分为读管道和写管道两种的情况 读管道 如果管道中有数据,read返回实际读到的字节数。 如果管道中无数据: 如果管道写端被全部关闭,read返回0,相当于读到文件结尾。

    82310
    领券