前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >java 字节流入门(内存数组流)

java 字节流入门(内存数组流)

作者头像
Apache IoTDB
发布2020-09-27 10:42:00
9810
发布2020-09-27 10:42:00
举报
文章被收录于专栏:Apache IoTDBApache IoTDB

上篇文章介绍了两种常用的文件输入输出流:java 字节流入门(文件流)

其中向文件中写入的数据都是预先定义好的字节数组 byte[] ,本文介绍另一种在内存中维护字节数组更常用的方式:内存数组输入输出流。

内存数组流,就是和内存中的数组相关的一个流,可以将字节数组写到输出流中,也可以将字节数组从输入流中读出来,不涉及磁盘。

内存数组输出流:ByteArrayOutputStream

内存数组输出流可以看成一个可自动扩容的 byte 数组,可以往里写字节。

默认初始化 32 个字节的大小。

最大容量是 2^31-9 个字节(2G)。只要数据不超过2G,都可以往里写。每次写数据之前,会先计算需要的容量大小,如果需要扩容,扩大到 max{原来的两倍,需要的容量大小}

此外,还可以将 ByteArrayOutputStream 中的字节数组拿出来,拿出来的只是真实存在的数据量。

为了验证扩容方式,把其内部缓冲区拿出来

工具类:

主要逻辑:

结果:

内存数组输入流:ByteArrayInputStream

这个输入流就是把一个字节数组 byte[] 包装了一下,使其具有流的属性,可顺序读下去。还可标记跳回来继续读。

结果:

为什么要用 ByteArrayInputStream 而不直接操作 byte 数组?有以下几种情况:

(1)其他接口需要一个 InputStream,而你只有一个 byte[],这时候必须包装一下。

(2)希望以流的方式操作字节数组。

如果其他地方只需要一个 byte[],就没必要包装了,直接传 byte[] 就好了。盲目使用流 是 流氓(大哥你可听到了!)

总结

这两个流都是对内存中的数据进行操作,在需要动态维护一个字节数组时,可以使用 ByteArrayOutputStream,这个变量通常叫 baos 。另外,此次代码和上次代码都放在 github 上了,可以点阅读原文,下边这个也是:

https://github.com/qiaojialin/Java-IO-Learning

致谢:东哥、大哥、康博

估计大部分人看完就返回了,懒得滑上去点关注了,放下来互利共赢~

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-05-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Apache IoTDB 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档