Java IO 节点流 ByteArrayInput/OutputStream

@author ixenos

ByteArrayInputStream


包含一个内部缓冲区(字节数组byte[]),该缓冲区包含从流中读取的字节。

关闭 ByteArrayInputStream 无效。此类中的方法在关闭此流后仍可被调用,而不会产生任何 IOException。 

#Constructors

ByteArrayInputStream(byte[] buf) //使用创建者预设的buf作为其缓冲区数组,通常buf就是数据源
ByteArrayInputStream(byte[] buf, int offset, int lenght) //使用buf作为其缓冲区数组,参数offset指定从数组中开始读取数据的起始下标位置,lenght指定从数组中读取的字节数。

 

int read(byte[] b, int off, int len) 
         从此字节输入流中给定偏移量处开始将各字节读取出来并写到指定的 byte 数组b中。

   返回:(本次)读取的字节数;如果已到达流末尾,则返回 -1

int  read()返回下一个字节,如果到达流末尾,则返回 -1

ByteArrayOutputStream


在内存中创建一个字节数组缓冲区,所有发送到输出流的数据保存在该字节数组缓冲区中。

缓冲区会随着数据的不断写入而自动增长。默认构造是32

可使用 toByteArray() 和 toString() 获取数据

关闭 ByteArrayOutputStream 无效。此类中的方法在关闭此流后仍可被调用,而不会产生任何 IOException

#字段protected int count  缓冲区中的有效字节数,即表示当前缓冲区中数据的字节数

#public void reset()  将此 byte 数组输出流的 count 字段重置为零,从而丢弃输出流中目前已累积的所有输出。通过重新使用已分配的缓冲区空间,可以再次使用该输出流。

#Constructors

OutputStream bOut = new ByteArrayOutputStream(); //创建一个32字节(默认大小)的缓冲区,内部是this(32),即调用了另一个构造器
OutputStream bOut = new ByteArrayOutputStream(int a); //创建一个大小为a字节的缓冲区,即new byte[a]

#Methods

public byte[] toByteArray()
创建一个新分配的字节数组。数组的大小和当前输出流的大小,内容是当前输出流的拷贝。
public String toString()
将缓冲区的内容转换为字符串,根据平台的默认字符编码将字节转换成字符。
public void write(int w)
 将指定的字节写入此字节数组输出流。
public void write(byte []b, int of, int len)
 将指定字节数组中从偏移量 off 开始的 len 个字节写入此字节数组输出流。
public void writeTo(OutputStream outSt)
将此字节数组输出流的全部内容写入到指定的输出流参数中。

关于内部缓冲区


  二者同时使用时缓冲区是没有联系的,但二者原理一致,作为中间缓存

#ByteArrayInputStream 先提供一个缓冲区存放需要的数据,该数组相当于数据源,读取时,从该数组取出 sender----->buf------>you

 1     //通过输入流读取一个字节的数据,实际上是在缓冲区buf中读
2 //buf - 可看作数据源
3 public synchronized int read() {
4 return (pos < count) ? (buf[pos++] & 0xff) : -1;
5 }
6
7 //通过输入流读取缓冲区的数据,读入存储数组b中
8 //b - 存储读入数据的缓冲区
9 public synchronized int read(byte b[], int off, int len) {
10 if (b == null) {
11 throw new NullPointerException();
12 } else if (off < 0 || len < 0 || len > b.length - off) {
13 throw new IndexOutOfBoundsException();
14 }
15
16 if (pos >= count) {
17 return -1;
18 }
19
20 int avail = count - pos;
21 if (len > avail) {
22 len = avail;
23 }
24 if (len <= 0) {
25 return 0;
26 }
27 System.arraycopy(buf, pos, b, off, len); //因为是数组对数组,所以直接copy过去
28 pos += len;
29 return len;
30 }

#ByteArrayOutputStream 数据源发送的数据暂时保存在该内部缓冲区中,写出时,从该数组取出 you------>buf------>receiver

  使用输出流时,我们是数据源,可以决定将什么输出,跟输入流给的东西可能关系不大。比如write(int w) 把一个字节(byte)w写入缓冲区中,这些写入最终都到缓冲区中。

  而为了得到缓冲区字节数组,要通过ByteArrayOutputStream的toByteArray()返回一个当前输出流拷贝,或者toString()将缓冲区数组内容按默认编码转成字符串

public synchronized byte toByteArray()[] {
return Arrays.copyOf(buf, count);
}
public synchronized String toString() {
return new String(buf, 0, count);
}

二者使用示例


例一:

// 与DataOutputStream&DataInputStream联合使用:
ByteArrayOutputStream bout=new ByteArrayOutputStream();
DataOutputStream dos=new DataOutputStream(bout);
String name="suntao";
int age=19;
dos.writeUTF(name);
dos.writeInt(age);
byte[] buf=bout.toByteArray();//获取内存缓冲区中的数据
dos.close();
bout.close(); ByteArrayInputStream bin=new ByteArrayInputStream(byte[] buf);
DataInputStream dis=new DataInputStream(bin);
String name=dis.readUTF();//从字节数组中读取
int age=dis.readInt();
dis.close();
bin.close();

例二: DataInputStream&DataOutputStream还可以与FileInputStream&FileOutputStream联合使用。

  多层嵌套:

  过滤流:DataInputStream&DataOutputStream关心如何将数据从高层次的形式转化成低层次的形式。

  过滤流:BufferedInputStream&BufferedOutputStream为另一个输入流添加一些功能,即缓冲输入以及支持 mark 和 reset 方法的能力。

  节点流:FileInputStream&FileOutputStream关心如何操作存储单元以接受和产生数据

import java.io.*;

public Test
{
public static void main(String[] args)
{
DataOutputStream dOut = new DataOutputStream( new BufferedOutputStream( new FileOutputStream("test.txt"))); byte b = 3;
int i = 12;
char ch = 'a';
float f = 3.3f; dOut.writeByte(b);
dOut.writeInt(i);
dOut.writeChar(ch);
dOut.writeFloat(f); dOut.close();
}
}

Java IO 节点流 ByteArrayInput/OutputStream的更多相关文章

  1. Java IO 节点流 FileInput/OutputStream

    Java IO 节点流 FileInput/OutputStream @author ixenos 节点流之 文件流 文件读写是最常见的I/O操作,通过文件流来连接磁盘文件,读写文件内容 1.文件的读 ...

  2. Java IO 过滤流 BufferedInput/OutputStream

    Java IO 过滤流 BufferedInput/OutputStream @author ixenos 概念 BufferedInput/OutputStream是实现缓存的过滤流,他们分别是Fi ...

  3. java io 节点流和处理流

    JAVA IO操作总结:节点流和处理流 JAVA IO操作总结--节点流和处理流  按照流是否直接与特定的地方(如磁盘.内存.设备等)相连,分为节点流和处理流两类. 节点流:可以从或向一个特定的地方( ...

  4. Java Io 字符流

    Java Io 字符流包含: 1. InputStreamReader  它是由byte流解析为char流,并且按照给定的编码解析. 2. OutputStreamWrite  它是char流到byt ...

  5. Java IO 转换流 字节转字符流

    Java IO 转换流 字节转字符流 @author ixenos 字节流 输入字节流:---------| InputStream 所有输入字节流的基类. 抽象类.------------| Fil ...

  6. Java - IO 内存流和打印流

    IO 内存流和打印流操作 字符编码 计算机中所有的信息组成都是二进制数据,所有能够描述的中文文字都是经过处理后的结果:所有的语言文字都会使用编码来进行描述,例如:ASCII码 常见编码 GBK/GB2 ...

  7. Java IO 嵌套流、文本的输入输出和存储

    Java IO 嵌套流.文本的输入输出和存储 @author ixenos 1.   组合流过滤器(嵌套流) a)    跨平台文件分割符:常量字符串 java.io.File.seperator 等 ...

  8. Java IO 理解流的概念

    Java IO 理解流的概念 @author ixenos 在理解流时首先理解以下概念 1.流的来源和去向一般在构造器指出 2.方法中的形参一般是将流输出到某个位置,读取(INPUT)流从流读出数据( ...

  9. Java IO: 字符流的Buffered和Filter

    作者: Jakob Jenkov  译者: 李璟(jlee381344197@gmail.com) 本章节将简要介绍缓冲与过滤相关的reader和writer,主要涉及BufferedReader.B ...

随机推荐

  1. Extjs控件属性

    Ext.form.TimeField: 配置项:            maxValue:列表中允许的最大时间            maxText:当时间大于最大值时的错误提示信息          ...

  2. Netty(7)源码-ByteBuf

    一.ByteBuf工作原理 1. ByteBuf是ByteBuffer的升级版: jdk中常用的是ByteBuffer,从功能角度上,ByteBuffer可以完全满足需要,但是有以下缺点: ByteB ...

  3. CentOS 添加本地yum源

    1 创建保存RPM包的路径: mkdir -p /share/CentOS/7/local/x86_64/RPMS 2 安装createrepo工具 yum install createrepo 3 ...

  4. 照片处理软件(iSee图片专家) 3.930 中文免费版

    软件名称: 照片处理软件(iSee图片专家) 软件语言: 简体中文 授权方式: 免费软件 运行环境: Win 32位/64位 软件大小: 13.5MB 图片预览: 软件简介: iSee图片专家,免费一 ...

  5. C# 实现客户端程序自动更新

    看到一篇不错的帖子,可能以后会用到,果断收藏 文章来源 博客园jenry(云飞扬)http://www.cnblogs.com/jenry/archive/2006/08/15/477302.html ...

  6. MVC之联动学习

    一,数据库表设计 CREATE TABLE [dbo].[HY_Province]( [id] [INT] NOT NULL, [province] [NVARCHAR]() NOT NULL, CO ...

  7. 能量项链AC了

    我打算写出一个尽量看起来像是人话的解题报告. 然而这道题我还是[虽然AC但不会做] OYZ

  8. 特性(Attributes)

    用以将元数据或声明信息与代码(程序集.类型.方法.属性等)相关联.特性与程序实体相关联后,即可在运行时用反射技术查询特性. 例如,在一个方法前标注[Obsolete]特性,则调用该方法时VS则会提示该 ...

  9. 【转】Jmeter(二)-使用代理录制脚本

    Jmeter脚本是以JMX格式为主 Jmeter也是支持录制的,支持第三方录制方式和代理录制方式. 1.第三方录制主要是通过badboy来录制,录制后另存为jmx格式即可. 2.Jmeter也有自己的 ...

  10. ABP组件包升级

    对于abp的爱好者来说在使用abp上会面临两个问题,第一个是如何上手,第二是如何升级,然而们今天的主题是如何升级abp的组件包.目前我项目版本是0.8.2 通过官网boilerplate生成的项目前端 ...