Java提供了很丰富的io接口,已经可以满足我们大部分读取数据的需求,这个在C读取数据需要自己定义缓冲区数组大小,而且要小心翼翼的防止缓冲区溢出的情况相当不同。一般情况下我们读取的数据都是直接读取成为String类型的,可是有些时候还是难免要读取成为二进制的数据。

  1. public int read(byte b[]) throws IOException {
  2. t;span style="white-space:pre">  </span>return readBytes(b, 0, b.length);
  3. }

这个是java提供Inputstream的接口,我们必须定义一个byte数组去接收数据,而且我们根本不知道数据有多大,这个时候就要自己写数据缓冲区还有自动增长的数组,太麻烦了。

Java已经提供了一个叫做ByteArrayOutputStream的类,这个类实现了一个输出流,内部的数据是写进自身维护的一个自动增长的byte数组,而且可以使用toByteArray()还有toString()来获得数据。

  1. public static byte[] read(InputStream in) throws IOException {
  2. BufferedInputStream bis = new BufferedInputStream(in);
  3. ByteArrayOutputStream baos = new ByteArrayOutputStream();
  4. int c = bis.read();
  5. while((c!=-1)){
  6. baos.write(c);
  7. c = bis.read();
  8. }
  9. bis.close();
  10. return baos.toByteArray();
  11. }

之所以为什么用Buffer来缓冲流来封装输入流,是因为使用了Buffer,jvm会自动把数据读取进去缓冲区,然后再从缓冲区直接读取,比直接从inputstream一个字节一个字节读取效率高。

============================================================================================================

  ByteArrayOutputStream类是在创建它的实例时,程序内部创建一个byte型别数组的缓冲区,

然后利用ByteArrayOutputStream和ByteArrayInputStream的实例向数组中写入或读出byte型数据。

在网络传输中我们往往要传输很多变量,我们可以利用ByteArrayOutputStream把所有的变量收集到一起,然后一次性把数据发送出去。

具体用法如下: 
ByteArrayOutputStream:    可以捕获内存缓冲区的数据,转换成字节数组  (从数组写)

ByteArrayInputStream: 可以将字节数组转化为输入流   (从数组读)

 1 public static void main(String[] args) {
2 int a = 0;
3 int b = 1;
4 int c = 2;
5 ByteArrayOutputStream bout = new ByteArrayOutputStream();
6 bout.write(a);
7 bout.write(b);
8 bout.write(c);
9 byte[] buff = bout.toByteArray();
10 for (int i = 0; i < buff.length; i++)
11 System.out.println(buff[i]);
12 System.out.println("***********************");
13 ByteArrayInputStream bin = new ByteArrayInputStream(buff);
14 while ((b = bin.read()) != -1) {
15 System.out.println(b);
16 }
17 }

如上所示,ByteArrayOutputStream把内存中的数据读到字节数组中,而ByteArrayInputStream又把字节数组中的字节以流的形式读出,实现了对同一个字节数组的操作.

综合DataOutputStream&DataInputStream的作用和功能,与ByteArrayOutputStream和ByteArrayInputSream使用将更方便.此时DataOutputStream&DataInputStream封闭了字节流,以适当的形式读出了字节数组中的数据.如下所示:

 1 public static void main(String[] args) throws IOException {
2 ByteArrayOutputStream bout = new ByteArrayOutputStream();
3 DataOutputStream dout = new DataOutputStream(bout);
4 String name = "xxy";
5 int age = 84;
6 dout.writeUTF(name);
7 dout.writeInt(age);
8 byte[] buff = bout.toByteArray();
9 ByteArrayInputStream bin = new ByteArrayInputStream(buff);
10 DataInputStream dis = new DataInputStream(bin);
11 String newName = dis.readUTF();
12 int newAge = dis.readInt();
13 System.out.println(newName + ":" + newAge);
14 }

概述

  • 此类实现了一个输出流,其中的数据被写入一个 byte 数组。缓冲区会随着数据的不断写入而自动增长。可使用 toByteArray() 和 toString() 获取数据

ByteArrayOutputStream

  • 构造方法
构造方法 说明
ByteArrayOutputStream() 创建一个新的 byte 数组输出流
ByteArrayOutputStream(int size) 创建一个新的 byte 数组输出流,它具有指定大小的缓冲区容量(以字节为单位)
  • 方法
方法 说明
write(int b) 将指定的字节写入此 byte 数组输出流
write(byte[] b, int off, int len) 将指定 byte 数组中从偏移量 off 开始的 len 个字节写入此 byte 数组输出流
toByteArray() 创建一个新分配的 byte 数组
toString() 使用平台默认的字符集,通过解码字节将缓冲区内容转换为字符串
toString(String charsetName) 使用指定的 charsetName,通过解码字节将缓冲区内容转换为字符串
FileInputStream input = null;

try{
// 创建输入流和内存输出流
input = new FileInputStream("a.txt");
ByteArrayOutputStream output = new ByteArrayOutputStream(); int b;
// 从文件读取数据,并写入到内存缓冲区中
while((b = input.read()) > 0) {
output.write(b);
} // 第一种获得数据的方式: 调用toByteArray方法,返回内存中的数据
byte[] byteArray = output.toByteArray();
System.out.println(new String(byteArray)); // 第二种获得数据的方式:调用toString方法,将内存中的数据解码成字符串
String content = output.toString();
System.out.println(content); }catch(IOException e) {
e.printStackTrace();
}finally {
try{
// 关闭输入流
if(input != null) {
input.close();
}
}catch(IOException e){
e.printStackTrace();
}
}

Java IO --ByteArrayOutputStream (六)***的更多相关文章

  1. 【java】内存流:java.io.ByteArrayInputStream、java.io.ByteArrayOutputStream、java.io.CharArrayReader、java.io.CharArrayWriter

    package 内存流; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java. ...

  2. Java IO(六) ObjectInputStream 和 ObjectOutputStream

    Java IO(六) ObjectInputStream 和 ObjectOutputStream 一.介绍 对于对象数据的处理,Java IO 提供了 ObjectInputStream 和 Obj ...

  3. 系统学习 Java IO (十六)----这么多类,应该用哪个?

    目录:系统学习 Java IO---- 目录,概览 Java IO目的和功能 Java IO 包含 InputStream,OutputStream,Reader 和 Writer 类的许多子类. 原 ...

  4. Java IO: ByteArrayOutputStream使用

    感谢原文作者:小思思smile 原文链接:https://blog.csdn.net/u014049880/article/details/52329333/ 更多请查阅Java API文档! 在创建 ...

  5. java.io.ByteArrayOutputStream 源码分析

    ByteArrayOutputStream 内部包含了一个缓冲区,缓冲区会随着数据的不断写入而自动增长,俗称内存流. 首先看一下俩个属性,buf是内部缓冲区,count是记录写入了多少个字节. pro ...

  6. Java IO流学习总结六:ByteArrayInputStream、ByteArrayOutputStream

    类的继承关系 InputStream |__ ByteArrayInputStream OutputStream |__ ByteArrayOutputStream ByteArrayInputStr ...

  7. java io系列03之 ByteArrayOutputStream的简介,源码分析和示例(包括OutputStream)

    前面学习ByteArrayInputStream,了解了“输入流”.接下来,我们学习与ByteArrayInputStream相对应的输出流,即ByteArrayOutputStream.本章,我们会 ...

  8. java io流 数据流 DataInputStream、DataOutputStream、ByteArrayInputStream、ByteArrayOutputStream

    例子程序: package io; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import ...

  9. Java IO 流-- 字节数组流ByteArrayInPutStream ByteArrayOutPutStream

    字节数组流输于缓冲流,放在jvm内存中,java可以直接操作.我们使用时可以不用关闭,交给GC垃圾回收机制处理. 当然我们为了保持良好习惯和代码一致性也可以加上关闭语句. 当其实我么打开ByteArr ...

随机推荐

  1. 第七章习题G题

    题意 给出如图案例,要你从某一点开始走,一直走到极限(即无法再进行扩展),这时你走过的点会连成一个数,不同的走法当然会有不同的数,要求是输出最大的数(注意每个方块走过一次就不能再走) 思路 •1.枚举 ...

  2. [luoguP1410] 子序列(DP)

    传送门 发现一个结论. 只要存在长度>=3的非严格下降子序列就是NO,反之就是YES #include <cstdio> #include <iostream> #def ...

  3. noip模拟赛 收集果子

    分析:显然的,树形dp,状态也很好想到:f[i][j]表示以i为根的子树收集到j个果子的方案数.转移的话就相当于是背包问题,每个子节点可以选或不选.如果不选子节点k的话,那么以k为根的子树的边无论断不 ...

  4. [K/3Cloud] 代码中设置某个字段必录

    Control ctl = this.GetControl(fieldKey); FieldEditor editCtl = ctl as FieldEditor; if (editCtl != nu ...

  5. 【51NOD1806】wangyurzee的树(Prufer编码,容斥原理,组合计数)

    题意:有n个点和m条限制,每条限制限制了一个点的度数不能为某个数. 求合法的树的个数模10^9+7 n<=10^6 m<=17 思路:WYZ作业 首先m<=17显然是2^m容斥 枚举 ...

  6. openjudge1944 吃糖果

    描述名名的妈妈从外地出差回来,带了一盒好吃又精美的巧克力给名名(盒内共有 N 块巧克力,20 > N >0).妈妈告诉名名每天可以吃一块或者两块巧克力.假设名名每天都吃巧克力,问名名共有多 ...

  7. Servlet CDI 例子分析

    @WebServlet("/cdiservlet") //以@WebServlet注释开头,注释指定相对于上下文根的URL模式,即在根目录下使用/cdiservlet来访问 pub ...

  8. Ubuntu 16.04安装TortoiseSVN(基于CrossOver)

    基于CrossOver的TortoiseSVN有如下缺点: 1.不能像Windows下实现右键菜单提交,但是可以通过TortoiseSVN实现迁出代码. 可以解决的问题: 1.可以通过Tortoise ...

  9. ADSL和ITV

    1.ADSL和ITV两者占用的是不同的虚通道,也就是使用不同的VLAN: 2.的确上通过不同的VPI/VCI来区分ADSL和ITV在不同通道,但不会互不影响的,因为使用的还是同一条线路的宽带速度: 3 ...

  10. 条款十: 如果写了operator new就要同时写operator delete

    为什么有必要写自己的operator new和operator delete? 答案通常是:为了效率.缺省的operator new和operator delete具有非常好的通用性,它的这种灵活性也 ...