第一次看到ByteArrayOutputStream的时候是在Nutch的部分源码,后来在涉及IO操做时频频发现这两个类的踪影,以为确实是很好用,因此把它们的用法总结一下。数组
ByteArrayOutputStream的用法缓存
如下是JDK中的记载: 网络
public class ByteArrayOutputStream extends OutputStream函数
此类实现了一个输出流,其中的数据被写入一个 byte 数组。缓冲区会随着数据的不断写入而自动增加。可以使用 toByteArray()和 toString()获取数据。spa
关闭 ByteArrayOutputStream 无效。此类中的方法在关闭此流后仍可被调用,而不会产生任何IOException。orm
个人我的理解是ByteArrayOutputStream是用来缓存数据的(数据写入的目标(output stream原义)),向它的内部缓冲区写入数据,缓冲区自动增加,当写入完成时能够从中提取数据。因为这个缘由,ByteArrayOutputStream经常使用于存储数据以用于一次写入。文档
实例:get
从文件中读取二进制数据,所有存储到ByteArrayOutputStream中。input
FileInputStream fis=new FileInputStream("test");源码
BufferedInputStream bis=new BufferedInputStream(fis);
ByteArrayOutputStream baos=new ByteArrayOutputStream();
int c=bis.read();//读取bis流中的下一个字节
while(c!=-1){
baos.write(c);
c=bis.read();
}
bis.close();
byte retArr[]=baos.toByteArray();
ByteArrayInputStream的用法
相对而言,ByteArrayInputStream比较少见。先看JDK文档中的介绍:
public class ByteArrayInputStreamextends InputStreamByteArrayInputStream 包含一个内部缓冲区,该缓冲区包含从流中读取的字节。内部计数器跟踪 read 方法要提供的下一个字节。
关闭 ByteArrayInputStream 无效。此类中的方法在关闭此流后仍可被调用,而不会产生任何 IOException。
构造函数:
ByteArrayInputStream(byte[] buf)
注意它须要提供一个byte数组做为缓冲区。
与大部分Inputstream的语义相似,能够从它的缓冲区中读取数据,因此咱们能够在它的外面包装另外一层的inputstream以使用咱们须要的读取方法。
我的认为一个比较好的用途是在网络中读取数据包,因为数据包通常是定长的,咱们能够先分配一个够大的byte数组,好比byte buf[]=new byte[1024];
而后调用某个方法获得网络中的数据包,例如:
Socket s=...;
DataInputStream dis=new DataInputStream(s.getInputStream());
dis.read(buf);//把全部数据存到buf中
ByteArrayInputStream bais=new ByteArrayInputStream(buf); //把刚才的部分视为输入流
DataInputStream dis_2=new DataInputStream(bais);
//如今可使用dis_2的各类read方法,读取指定的字节
好比第一个字节是版本号,dis_2.readByte();
等等……
上面的示例的两次包装看上去有点画蛇添足,但使用ByteArrayInputStream的好处是关掉流以后它的数据仍然存在。