(每日持续更新)jdk api之ByteArrayInputStream基础、应用、实战
yuyutoo 2024-10-12 01:31 5 浏览 0 评论
博主18年的互联网软件开发经验,从一名程序员小白逐步成为了一名架构师,我想通过平台将经验分享给大家,因此博主每天会在各个大牛网站点赞量超高的博客等寻找该技术栈的资料结合自己的经验,晚上进行用心精简、整理、总结、定稿,每天都会整理到12点,为了就是能让大家能够真正了解该技术栈的真正原理,最终从程序员成为一名真正的架构师,写的不一定是全站做好的,但是是全站最用心的~~~~~。
以后我会推出一些列的文章,每天都会更新,每天进步一点点,发布顺序【java的api基础、应用、实战】->【java开源技术栈及源码分析】->【java开源技术栈整合】->【java低代码开发平台的建设】
1.10 ByteArrayInputStream
ByteArrayInputStream 是 InputStream 的一个实现类,它使用字节数组作为数据源。通过 ByteArrayInputStream,可以将一个字节数组当做输入流来读取数据。
ByteArrayInputStream 所有字段:
ByteArrayInputStream 类没有公共字段。
ByteArrayInputStream 构造方法:
- ByteArrayInputStream(byte[] buf):
- 使用给定的字节数组 buf 创建一个 ByteArrayInputStream。
- ByteArrayInputStream(byte[] buf, int offset, int length):
- 使用给定的字节数组 buf、偏移量 offset 和长度 length 创建一个 ByteArrayInputStream,表示从数组中的指定范围读取数据。
ByteArrayInputStream 方法摘要:
- int read():
- 从输入流中读取下一个字节的数据。如果已经到达流的末尾,返回 -1。
- int read(byte[] b, int off, int len):
- 从输入流中最多读取 len 个字节的数据到字节数组 b 中,从偏移量 off 开始存储。返回实际读取的字节数,如果已经到达流的末尾,返回 -1。
- long skip(long n):
- 跳过输入流中的 n 个字节。返回实际跳过的字节数。
- int available():
- 返回剩余可读取的字节数。
- void mark(int readlimit):
- 在当前流位置设置标记,最多允许跳过 readlimit 个字节。
- void reset():
- 将流的位置重置到最后一次调用 mark 方法设置的位置。
- boolean markSupported():
- 判断此流是否支持 mark 和 reset 操作。
简单使用例子:
javaCopy code
import java.io.ByteArrayInputStream;
import java.io.IOException;
public class ByteArrayInputStreamExample {
?
public static void main(String[] args) {
// 创建字节数组
byte[] data = { 65, 66, 67, 68, 69 };
?
// 使用 ByteArrayInputStream 封装字节数组
try (ByteArrayInputStream inputStream = new ByteArrayInputStream(data)) {
// 读取字节并打印
int byteRead;
while ((byteRead = inputStream.read()) != -1) {
System.out.print((char) byteRead + " ");
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
在这个简单的例子中,通过使用 ByteArrayInputStream 封装一个字节数组 data,然后使用 read 方法逐字节读取数据并将其转换为字符进行打印。请注意,这里使用了 try-with-resources 语句,确保 ByteArrayInputStream 被正确关闭。
应用场景
ByteArrayInputStream 主要适用于以下一些场景:
- 测试和单元测试:
- 在测试中,可能需要模拟一个输入流来测试某个类的输入处理逻辑。使用 ByteArrayInputStream 可以轻松创建一个包含测试数据的输入流,以便进行单元测试。
javaCopy code
byte[] testData = "Test data for unit testing.".getBytes();
InputStream testInputStream = new ByteArrayInputStream(testData);
// 使用 testInputStream 进行单元测试
- 内存数据读取:
- 当有一个字节数组存储在内存中,并且需要将其作为输入流读取时,可以使用 ByteArrayInputStream。
javaCopy code
byte[] memoryData = getMemoryData();
InputStream memoryInputStream = new ByteArrayInputStream(memoryData);
// 使用 memoryInputStream 读取内存数据
- 数据处理:
- 在一些数据处理场景中,可能需要将字节数组中的数据通过输入流的方式传递给某个方法或组件。
javaCopy code
byte[] processData = getDataToProcess();
InputStream processInputStream = new ByteArrayInputStream(processData);
processData(processInputStream);
- 资源加载:
- 在某些情况下,资源可能被加载到字节数组中,而不是从文件系统或网络中加载。ByteArrayInputStream 可以用于将这些字节数组包装成输入流,以便进行后续的处理。
javaCopy code
byte[] resourceData = loadResourceData();
InputStream resourceInputStream = new ByteArrayInputStream(resourceData);
// 对 resourceInputStream 进行进一步的处理
- 缓存处理:
- 当一些缓存数据以字节数组形式存在时,ByteArrayInputStream 可以用于将缓存数据作为输入流供其他模块使用。
javaCopy code
byte[] cacheData = getCacheData();
InputStream cacheInputStream = new ByteArrayInputStream(cacheData);
// 使用 cacheInputStream 进行缓存数据的读取
总体而言,ByteArrayInputStream 在需要将字节数组当做输入流使用的场景中非常有用。由于它是基于内存的,因此在一些内存操作和数据处理的场景中,它提供了一种方便的方式来处理字节数据。
实战例子
例子一
在一个实际项目中,ByteArrayInputStream 可以用于将字节数组转换为输入流,以便进行进一步的处理。以下是一个简化的例子,模拟一个图像处理系统,其中图像数据以字节数组的形式存在,并使用 ByteArrayInputStream 进行处理。
图像处理系统:
javaCopy code
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;
?
public class ImageProcessingSystem {
?
public static void main(String[] args) {
// 从文件中读取图像数据的字节数组
byte[] imageData = readImageDataFromFile("input_image.jpg");
?
// 使用 ByteArrayInputStream 封装图像数据
try (ByteArrayInputStream inputStream = new ByteArrayInputStream(imageData)) {
// 处理图像数据
processImage(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
?
private static byte[] readImageDataFromFile(String filePath) {
Path imagePath = Paths.get(filePath);
try {
return Files.readAllBytes(imagePath);
} catch (IOException e) {
e.printStackTrace();
return new byte[0];
}
}
?
private static void processImage(ByteArrayInputStream inputStream) throws IOException {
// 通过 ImageIO 读取图像数据
BufferedImage image = ImageIO.read(inputStream);
?
// 在实际项目中,可以进行各种图像处理操作,例如调整大小、应用滤镜等
// 这里仅打印图像信息作为演示
System.out.println("Image Width: " + image.getWidth());
System.out.println("Image Height: " + image.getHeight());
System.out.println("Image Type: " + image.getType());
}
}
在这个例子中,ImageProcessingSystem 类通过 readImageDataFromFile 方法从文件中读取图像数据的字节数组,然后使用 ByteArrayInputStream 封装这些图像数据。接下来,通过 processImage 方法使用 ImageIO 读取 ByteArrayInputStream 中的图像数据并进行简单的处理。在实际项目中,可以根据需求进行更复杂的图像处理操作。
例子二
下面是一个使用 ByteArrayInputStream 的完整示例,演示了如何将字符串数据写入字节数组,然后使用 ByteArrayInputStream 封装字节数组进行读取操作:
javaCopy code
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
?
public class ByteArrayInputStreamExample {
?
public static void main(String[] args) {
// 字符串数据
String inputData = "Hello, ByteArrayInputStream!";
?
// 将字符串数据转换为字节数组
byte[] byteArray = inputData.getBytes();
?
// 使用 ByteArrayInputStream 封装字节数组
try (InputStream inputStream = new ByteArrayInputStream(byteArray)) {
// 读取字节并打印
int byteRead;
while ((byteRead = inputStream.read()) != -1) {
System.out.print((char) byteRead);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
在这个例子中,我们首先将字符串数据 "Hello, ByteArrayInputStream!" 转换为字节数组 byteArray,然后使用 ByteArrayInputStream 封装这个字节数组。随后,通过 InputStream 的 read 方法逐字节读取数据,并将其转换为字符进行打印。最后,由于 ByteArrayInputStream 实现了 AutoCloseable 接口,我们使用 try-with-resources 语句确保输入流被正确关闭。
这个例子演示了如何使用 ByteArrayInputStream 将字节数组中的数据作为输入流进行读取,适用于一些需要处理字节数组数据的场景。
相关推荐
- Mysql和Oracle实现序列自增(oracle创建序列的sql)
-
Mysql和Oracle实现序列自增/*ORACLE设置自增序列oracle本身不支持如mysql的AUTO_INCREMENT自增方式,我们可以用序列加触发器的形式实现,假如有一个表T_WORKM...
- 关于Oracle数据库12c 新特性总结(oracle数据库19c与12c)
-
概述今天主要简单介绍一下Oracle12c的一些新特性,仅供参考。参考:http://docs.oracle.com/database/121/NEWFT/chapter12102.htm#NEWFT...
- MySQL CREATE TABLE 简单设计模板交流
-
推荐用MySQL8.0(2018/4/19发布,开发者说同比5.7快2倍)或同类型以上版本....
- mysql学习9:创建数据库(mysql5.5创建数据库)
-
前言:我也是在学习过程中,不对的地方请谅解showdatabases;#查看数据库表createdatabasename...
- MySQL面试题-CREATE TABLE AS 与CREATE TABLE LIKE的区别
-
执行"CREATETABLE新表ASSELECT*FROM原表;"后,新表与原表的字段一致,但主键、索引不会复制到新表,会把原表的表记录复制到新表。...
- Nike Dunk High Volt 和 Bright Spruce 预计将于 12 月推出
-
在街上看到的PandaDunk的超载可能让一些球鞋迷们望而却步,但Dunk的浪潮仍然强劲,看不到尽头。我们看到的很多版本都是为女性和儿童制作的,这种新配色为后者引入了一种令人耳目一新的新选择,而...
- 美国多功能舰载雷达及美国海军舰载多功能雷达系统技术介绍
-
多功能雷达AN/SPY-1的特性和技术能力,该雷达已经在美国海军服役了30多年,其修改-AN/SPY-1A、AN/SPY-1B(V)、AN/SPY-1D、AN/SPY-1D(V),以及雷神...
- 汽车音响怎么玩,安装技术知识(汽车音响怎么玩,安装技术知识视频)
-
全面分析汽车音响使用或安装技术常识一:主机是大多数人最熟习的音响器材,有关主机的各种性能及规格,也是耳熟能详的事,以下是一些在使用或安装时,比较需要注意的事项:LOUDNESS:几年前的主机,此按...
- 【推荐】ProAc Response系列扬声器逐个看
-
有考牌(公认好声音)扬声器之称ProAcTablette小音箱,相信不少音响发烧友都曾经,或者现在依然持有,正当大家逐渐掌握Tablette的摆位设定与器材配搭之后,下一步就会考虑升级至表现更全...
- #本站首晒# 漂洋过海来看你 — BLACK&DECKER 百得 BDH2000L无绳吸尘器 开箱
-
作者:初吻给了烟sco混迹张大妈时日不短了,手没少剁。家里有了汪星人,吸尘器使用频率相当高,偶尔零星打扫用卧式的实在麻烦(汪星人:你这分明是找借口,我掉毛是满屋子都有,铲屎君都是用卧式满屋子吸的,你...
- 专题|一个品牌一件产品(英国篇)之Quested(罗杰之声)
-
Quested(罗杰之声)代表产品:Q212FS品牌介绍Quested(罗杰之声)是录音监听领域的传奇品牌,由英国录音师RogerQuested于1985年创立。在成立Quested之前,Roger...
- 常用半导体中英对照表(建议收藏)(半导体英文术语)
-
作为一个源自国外的技术,半导体产业涉及许多英文术语。加之从业者很多都有海外经历或习惯于用英文表达相关技术和工艺节点,这就导致许多英文术语翻译成中文后,仍有不少人照应不上或不知如何翻译。为此,我们整理了...
- Fyne Audio F502SP 2.5音路低音反射式落地音箱评测
-
FyneAudio的F500系列,有新成员了!不过,新成员不是新的款式,却是根据原有款式提出特别版。特别版产品在原有型号后标注了SP字样,意思是SpecialProduction。Fyne一共推出...
- 有哪些免费的内存数据库(In-Memory Database)
-
以下是一些常见的免费的内存数据库:1.Redis:Redis是一个开源的内存数据库,它支持多种数据结构,如字符串、哈希表、列表、集合和有序集合。Redis提供了快速的读写操作,并且支持持久化数据到磁...
- RazorSQL Mac版(SQL数据库查询工具)
-
RazorSQLMac特别版是一款看似简单实则功能非常出色的SQL数据库查询、编辑、浏览和管理工具。RazorSQLformac特别版可以帮你管理多个数据库,支持主流的30多种数据库,包括Ca...
你 发表评论:
欢迎- 一周热门
-
-
前端面试:iframe 的优缺点? iframe有那些缺点
-
带斜线的表头制作好了,如何填充内容?这几种方法你更喜欢哪个?
-
漫学笔记之PHP.ini常用的配置信息
-
其实模版网站在开发工作中很重要,推荐几个参考站给大家
-
推荐7个模板代码和其他游戏源码下载的网址
-
[干货] JAVA - JVM - 2 内存两分 [干货]+java+-+jvm+-+2+内存两分吗
-
正在学习使用python搭建自动化测试框架?这个系统包你可能会用到
-
织梦(Dedecms)建站教程 织梦建站详细步骤
-
【开源分享】2024PHP在线客服系统源码(搭建教程+终身使用)
-
2024PHP在线客服系统源码+完全开源 带详细搭建教程
-
- 最近发表
-
- Mysql和Oracle实现序列自增(oracle创建序列的sql)
- 关于Oracle数据库12c 新特性总结(oracle数据库19c与12c)
- MySQL CREATE TABLE 简单设计模板交流
- mysql学习9:创建数据库(mysql5.5创建数据库)
- MySQL面试题-CREATE TABLE AS 与CREATE TABLE LIKE的区别
- Nike Dunk High Volt 和 Bright Spruce 预计将于 12 月推出
- 美国多功能舰载雷达及美国海军舰载多功能雷达系统技术介绍
- 汽车音响怎么玩,安装技术知识(汽车音响怎么玩,安装技术知识视频)
- 【推荐】ProAc Response系列扬声器逐个看
- #本站首晒# 漂洋过海来看你 — BLACK&DECKER 百得 BDH2000L无绳吸尘器 开箱
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)