[七]JavaIO之 PipedInputStream 和 PipedInputStream
管道简介
|
|
|
管道的含义,很久之前就已经出现 用于表示数据直接交互 |
|
它的含义与平时说的管道的含义是类似的,就是直连 JavaIO中的 PipedInputStream 和 PipedOutputStream 就是IO体系中字节流的管道
|
|
java中,PipedOutputStream和PipedInputStream分别是管道输出流和管道输入流 |
|
使用管道通信时,必须将PipedOutputStream和PipedInputStream配套使用 |
|
大致流程: 我们在线程A中向PipedOutputStream中写入数据,这些数据会自动的发送到与PipedOutputStream对应的PipedInputStream中,进而存储在PipedInputStream的缓冲中; 线程B通过读取PipedInputStream中的数据 |
|
对照到我上面画的图就是这样:
|
|
虽然说是管道,跟现实中的含义有些类似,但是也绝对不能认为他们的数据流方向可以任意 在JavaIO中必须是一个线程通过PipedOutputStream 写入数据,另外的线程通过与他相连接的PipedInputStream读取数据 |
实现原理
|
PipedOutputStream 中有一个 pipedInputStream pipedInputStream 内部有一个字节数组 通过initPipe方法进行初始化 |
|
调用PipedOutputStream的write方法,实际上调用的是内部pipedInputStream 的 receive方法 而 receive方法,操作的正是pipedInputStream内部的字节数组 所以说,只需要使用connect把管道连接起来 就可以通过PipedOutputStream 写入数据,PipedOutputStream读取数据 数据的中转站,正是pipedInputStream 内的数组 |
|
|
PipedInputStream
|
刚才已经介绍,PipedInputStream 内部维护了一个字节数组 buffer 默认大小为1024 通过initPipe方法初始化
|
|
PipedOutputStream 和 PipedInputStream 他们其实操作的都是 PipedInputStream 中的buffer 一个读一个写,所以要记住读和写的位置 注意 此处的in和 out 是相对于 PipedInputStream 的buffer[] 来说的 所以in就是 PipedOutputStream 调用write最终使用的 out就是 PipedInputStream 本身read使用的
|
|
想要使用管道流必须要有连接的过程 可以在创建 PipedInputStream 的同时一并连接 或者仅仅创建PipedInputStream 稍后连接 而且,内部字节数组的长度是可以设置的,所以也就是又有了默认的或者设置的两种形式 所以总共有四种形式的构造方法 |
|
|
read
|
public synchronized int read() throws IOException 读取一个字节 |
|
public synchronized int read(byte b[], int off, int len) 读取长度为len的字节到字节数组b 从偏移量off开始写入 |
|
available() 获取可用个数 |
|
close() 没有系统资源需要关闭,但是还是有些事情要做 |
connect
|
connect 调用的是PipedOutputStream中的connect方法 |
|
|
PipedOutputStream
|
内部需要PipedInputStream
|
|
构造方法也比较简单 创建一个PipeOutputStream或者创建的同时进行连接
|
|
刚才讲过,PipedInputStream中的connect也是借助于PipedOutputStream 他完成了真正的连接 看得出来,不能重复连接,否则会抛出异常 连接后,会对连接进来的PipedInputStream进行必要的初始化 主要就是 in和 out 另外标记已经连接,也正是用这个connected字段来校验是否已经连接的
|
write
|
两个版本的write方法 write(int b) 写入一个字节, 前面24位会被丢弃 write(byte b[], int off, int len) 从指定字节数组的指定位置,读取指定个数的字节, 写入到流 根本还是调用的receive |
|
|
flush
|
flush 将数据输出,此处不同于文件需要调用操作系统进行写入磁盘 需要通知读线程进行读取 |
|
|
close
|
|
对于管道流的学习,只需要了解其根本即可,那就是PipedOutputStream 内部指向了一个 PipedInputStream
借助于PipedInputStream 内部的循环数组进行数据缓存,进而达到多线程通信的目的
read 和 write方法的含义用法跟InputStream要求的是一样的,没什么特别的
实现细节有兴趣的可以深入研究
[七]JavaIO之 PipedInputStream 和 PipedInputStream的更多相关文章
- Java-IO之管道(PipedInputStream和PipedOutputStream)
java中PipedInputStream和PipedOutputStream分别是管道输入流和管道输出流,它的作用是让多线程可以通过管道进行线程间的通讯,在使用管道通信时,必须将PipedInput ...
- java 管道流PipedInputStream,PipedInputStream和随机访问文件 RandomAccessFile
http://blog.csdn.net/zlp1992/article/details/50298195 给个链接自己去看吧.网上资料不是很多,而且自己也不想写了 RandomAccessFil ...
- PipedInputStream和PipedOutputStream详解
PipedInputStream类与PipedOutputStream类用于在应用程序中创建管道通信.一个PipedInputStream实例对象必须和一个PipedOutputStream实例对象进 ...
- Java 管道PipedInputStream PipedOutStream PipedReader PipedWriter
java中的管道流(pipeStream)是一种特殊的流,用于在不同线程间直接传送数据.一个线程发送数据到输出管道,另外一个线程从输入管道中读取数据.通过使用管道,实现不同线程间的通信,而不必借助类似 ...
- Java中的管道流 PipedOutputStream和PipedInputStream
我们在学习IO流的时候可能会学字节流.字符流等,但是关于管道流的相信大部分视频或者教程都是一语带过,第一个是因为这个东西在实际开发中用的也不是很多,但是学习无止境,存在既有理.JDK中既然有个类那说明 ...
- Java IO(八) PipedInputStream 和 PipedOutputStream
Java IO(八) PipedInputStream 和 PipedOutputStream 一.介绍 PipedInputStream 和 PipedOutputStream 是管道输入流和管道输 ...
- java 多线程:线程通信-等待通知机制wait和notify方法;(同步代码块synchronized和while循环相互嵌套的差异);管道通信:PipedInputStream;PipedOutputStream;PipedWriter; PipedReader
1.等待通知机制: 等待通知机制的原理和厨师与服务员的关系很相似: 1,厨师做完一道菜的时间不确定,所以厨师将菜品放到"菜品传递台"上的时间不确定 2,服务员什么时候可以取到菜,必 ...
- javaIO整理
写在前面:本文章基本覆盖了java IO的全部内容,java新IO没有涉及,因为我想和这个分开,以突出那个的重要性,新IO哪一篇文章还没有开始写,估计很快就能和大家见面.照旧,文章依旧以例子为主,因为 ...
- java IO流详解
流的概念和作用 学习Java IO,不得不提到的就是JavaIO流. 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输 ...
随机推荐
- NOIP2012提高组day2 T2借教室
这题骗分可以骗到满分(可能是数据不太强给强行过去了) 这道题如果是按照题意去模拟用循环去修改区间的话只有45分,正解是二分+差分数组,骗分也是差分数组但是没有使用二分,时间复杂度在最坏的情况下是O(n ...
- CF1097G Vladislav and a Great Legend
传送门 题目大意 一棵$n$个点的树,一个点集$S$的权值定义为把这个点击连成一个联通块的最少边数,求: $$ans=\sum_{S\in U}f(S)^k$$ 题解 这题跟gdoi那道题差不多 先把 ...
- 登录MES系统后台服务的操作
一:使用GIt Bash Here打开服务 文件名:MES-Server-API-SC 输入:yarn server//打开服务 文件名:MES-server-API 输入:yarn local//本 ...
- 配置JDK环境变量与配置JRE
1. 如何配置jdk,x下载jdk 网站: https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-21 ...
- vue中计算属性computed方法内传参
vue中computed计算属性无法直接进行传参 如果有传参数的需求比如说做数据筛选功能可以使用闭包函数(也叫匿名函数)实现 例如: 在上篇博客vue安装使用最后的成绩表练习中的过滤功能的实现: &l ...
- linux学习:网络(防火墙)及系统安全相关命令学习
指令: top.htop.free.pstree.lsof.ifconfig.w3m.tcpdump.netstat.nmap.ufw 网络: top #查看内存,cpu,进程之间的状态.hto ...
- Nginx负载均衡的5种策略(转载)
Nginx的upstream目前支持的5种方式的分配 轮询(默认) 每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除. upstream backserver { s ...
- js杨辉三角控制台输出
function Yang(line){ var arr=new Array() ;i<=line;i++){ ]==undefined){arr[i-]=[];} ){arr[]=[i]}){ ...
- 【mysql】must reset your password using ALTER USER statement before executing this statement
问题描述: must reset your password using ALTER USER statement before executing this statement 登录centos服务 ...
- JVM,Tomcat与OSGi类加载机制比较
首先一个思维导图来看下Tomcat的类加载机制和JVM类加载机制的过程 类加载 在JVM中并不是一次性把所有的文件都加载到,而是一步一步的,按照需要来加载. 比如JVM启动时,会通过不同的类加载器加载 ...