java中的filter流简介
? ? ? ? 在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();
}
}
}
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!