------- android培训、java培训、期待与您交流! ----------
为了提高字节流对文件的读写效率,同样也使用了缓冲区。
缓冲区应用了两个类,从类名的前缀就能看出来,一个是BufferedInputStream类,另一个是BufferedOutputStream类。
BufferedInputStream类,作为另一种输入流,BufferedInputStream
为添加了功能,即缓冲输入和支持 mark
和 reset
方法的能力。创建 BufferedInputStream
时即创建了一个内部缓冲区数组。读取或跳过流中的各字节时,必要时可根据所包含的输入流再次填充该内部缓冲区,一次填充多个字节。mark
操作记录输入流中的某个点,reset
操作导致在从所包含的输入流中获取新的字节前,再次读取自最后一次 mark
操作以来所读取的所有字节。
构造函数中要传入一个文件读取流对象BufferedInputStream(InputStream in) ,BufferedInputStream(InputStream in, int size)其中size指定缓冲区大小。
将内容读取到缓冲区方法:read()和read(byte[] b, int off, int len)
同样也有返回可以不受阻塞地从此输入流读取的字节数的方法available()
BufferedOutputStream类实现缓冲的输出流。通过设置这种输出流,应用程序就可以将各个字节写入基础输出流中,而不必为每次字节写入调用基础系统。
创建缓冲区对象的时候也要传入写文件字节流对象BufferedOutputStream(OutputStream out) 。
方法:write(byte[] b, int off, int len) 将指定 byte 数组中从偏移量 off
开始的 len
个字节写入此缓冲的输出流
write(int b)将指定的字节写入此缓冲的输出流
既然有缓冲区,但是也要有个一个刷新缓冲区的方法flush()。
有一段代码模拟BufferedInputStream类的原理:
import java.io.*;
class MyBufferedInputStream{
private InputStream in;
private byte[] buf = new byte[1024];
private int pos = 0,count = 0;
MyBufferedInputStream(InputStream in){
this.in = in;
}
//一次读一个字节,从缓冲区获取
public int myRead()throws IOException{
//通过in对象读取硬盘上的数据,并存储在buf中。
if(count==0){
count = in.read(buf);
if(count<0)
return -1;
pos = 0;
byte b = buf[pos];
count --;
pos++;
return b&255;
}else if(count>0){
byte b = buf[pos];
count --;
pos++;
return b&0xff;
}
return -1;
}
public void myClose() throws IOException{
in.close();
}
}
上面代码中return b&255,是转化过程,从文件中读取的一个字节有可能8位全是1,转为十进制就是-1,而返回-1读取就结束了。&255,在二进制中就会转成32位的int类型保证内容的完整性,不会丢失数据,在写入另外一个文件的时候再用强转,把32位int转换成一个字节存入文件。