zoukankan      html  css  js  c++  java
  • [十五]javaIO之SequenceInputStream

    功能简介

     
    SequenceInputStream  合并流
    顾名思义,就是可以吧两个流合并起来
     
    他并没有很复杂,单纯的很,仅仅实现了InputStream
    image_5b992d23_58a2
    他拥有两个构造方法
    把两个InputStream 
    或者一个InputStream类型的Enumeration中包含的所有的流
    连接起来
    public SequenceInputStream(Enumeration<? extends InputStream> e)
    public SequenceInputStream(InputStream s1, InputStream s2) 
     

    实现原理

    所谓的连接,只是顺序的读取多个流而已
    接下来,我们详细看下
    内部包含一个in 以及一个Enumeration
    in用来表示当前的流
    Enumeration保存了所有的流
    image_5b992d23_5e82
    如果构造方法入参为Enumeration
    直接内部的Enumeration指向参数
    image_5b992d23_25ec
    如果传递的是两个InputStream
    创建一个Vector,将这两个流添加到Vector中
    然后调用Vector的elements 获得Enumeration
    image_5b992d23_403e
     
    可以看得到,构造方法中都调用了nextStream这个方法
    他是用来给in赋值的
    如果是第一次调用,in肯定为null,所以不会进入第一行的if   会从Enumeration中读取一个流,赋值给in
    如果是后来的调用,会把in指向的流进行close,然后在获取下一个流
    显然,这个方法的场景就是构造方法执行之后的初始化
    以及当一个流读取数组结束之后,尝试从下一个流读取
    image_5b992d23_6c8c
     
    read()方法将会持续从in中读取数据
    从一个流读取数据,如果不是-1 返回,如果是那么更新当前的in 指向下一个流
    然后如果in不为null,进行读取 如果不是-1 返回,如果是那么更新当前的in 指向下一个流
    .........
    直到最后一个流, in就是一个游标
    image_5b992d23_4f03

    多参数的也是类似
    从流中读取数据,如果读取到了,返回n,数据写入到字节数组b中了
    如果n<=0 说明 当前的in读取结束了
    那么调用nextStream 然后do  while循环读取
    image_5b992d23_25e6
     
     
    因为in始终指向当前的流,如果当前流为null,那么的确没有可用的
    否则直接返回  in.available
    image_5b992d23_4912
     
    close方法更直接
    从头到尾通过nextStream遍历一遍所有的流
    nextStream方法会把当前的流close掉
    也就完成了所有的流的关闭
    image_5b992d23_3fff
     

    总结

    SequenceInputStream的使用比较简单,只需要传递进入两个流或者一个包含流的Enumeration即可
    他的read方法与InputStream方法的语义是相同的
    再就没有任何难点了
    换句话说,只要通过构造方法构造好了SequenceInputStream之后,就当做什么都没发生,他就是一个最基础的InputStream
     
    需要了解到,它内部的实现细节,就是不断地循环遍历内部的流
     
     
     
     
     
     
     
     
     
  • 相关阅读:
    shell中逻辑与的两种表示方法
    Git学习之Git恢复进度
    RH318之域控服务器
    《征服C指针》读书笔记
    2013年:一个技术领导的启程
    sqlite的一个Unable to Open database file的坑爹错误
    我的2013——青春的躁动
    C/C++注册动态对象到Lu系统并进行运算符重载
    Geeks面试题:Min Cost Path
    Leetcode Gray Code
  • 原文地址:https://www.cnblogs.com/noteless/p/9638051.html
Copyright © 2011-2022 走看看