java中的filter流简介

2024-01-02 13:54:12

? ? ? ? 在java的io包下有四种类型的filter流,分别是:FilterInputStream、FilterOutputStream、FilterReader、FilterWriter,在java的io流分类中,它们属于处理流,与处理流对应的是节点流,节点流是直接与数据源连接的io流,它们直接操作磁盘或者内存,而处理流是对于节点流的包装,为节点流提供了新的功能,这四种处理流对应的节点流分别是InputStream、OutputStream、Reader、Writer。

? ? ? ? filter流是装饰器模式的实现,那么什么是装饰器模式呢?当我们想要去为某个类添加新的功能,但是又不想修改类本身,这个时候就可以用装饰器模式了:定义装饰器类,在装饰器类内部持有被装饰类的引用,并在装饰器类内部为被装饰类扩展功能。一般我们要定义一个抽象的装饰器类,在这个抽象类内部持有被装饰类的引用,然后为这个抽象类定义多个具体的实现类,实现不同的装饰功能。FilterInputStream、FilterOutputStream、FilterReader、FilterWriter这四个filter流就是抽象类,它们各自都有多个不同的具体实现类,以FilterInputStream的BufferdInputStream实现为例做一下简单介绍:

????????BufferedInputStream没有无参的构造器,它的构造器有一个InputStream类型的构造参数,这个InputStream流对象就是BufferedInputStream所要包装的节点流,BufferedInputStream的read方法支持传入一个byte[]类型的参数,这个byte数组在read方法的执行过程中将被作为数据缓冲区使用,不同于InputStream的节点流的read方法一次只能从数据源读取一个字节的数据使用,BufferedInputStream的read方法通过节点流一次性能从数据源读取多个字节的数据暂存在byte数组中待用,当要使用数据时,从byte数组中读取,byte数组中的数据读取使用完毕后,又能一次性读取一批数据到byte数组中。BufferedInputStream通过引入byte[]作为数据缓冲区,减少了真正的io操作发生的次数,提高了io流的执行效率。

? ? ? ??

import java.io.BufferedInputStream;
import java.io.FileInputStream;

/**
 * BufferedInputStream:处理流,缓冲输入流
 * @author Administrator
 *
 */
public class BISDemo01 {
    public static void main(String[] args){
        try {
            FileInputStream fis=new FileInputStream("BISDemo.txt");
            BufferedInputStream bis=new BufferedInputStream(fis);
            String content=null;
             //自己定义一个缓冲区
            byte[] buffer=new byte[10240];
            int flag=0;
            while((flag=bis.read(buffer))!=-1){
                content+=new String(buffer, 0, flag);
            }
            System.out.println(content);
            //关闭的时候只需要关闭最外层的流就行了
            bis.close();
        } catch (Exception e) {
                e.printStackTrace();
        }
    }
}

文章来源:https://blog.csdn.net/qq_39350797/article/details/135332481
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。