百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

(每日持续更新)jdk api之ByteArrayInputStream基础、应用、实战

yuyutoo 2024-10-12 01:31 9 浏览 0 评论

博主18年的互联网软件开发经验,从一名程序员小白逐步成为了一名架构师,我想通过平台将经验分享给大家,因此博主每天会在各个大牛网站点赞量超高的博客等寻找该技术栈的资料结合自己的经验,晚上进行用心精简、整理、总结、定稿,每天都会整理到12点,为了就是能让大家能够真正了解该技术栈的真正原理,最终从程序员成为一名真正的架构师,写的不一定是全站做好的,但是是全站最用心的~~~~~。

以后我会推出一些列的文章,每天都会更新,每天进步一点点,发布顺序【java的api基础、应用、实战】->【java开源技术栈及源码分析】->【java开源技术栈整合】->【java低代码开发平台的建设】

1.10 ByteArrayInputStream

ByteArrayInputStreamInputStream 的一个实现类,它使用字节数组作为数据源。通过 ByteArrayInputStream,可以将一个字节数组当做输入流来读取数据。

ByteArrayInputStream 所有字段:

ByteArrayInputStream 类没有公共字段。

ByteArrayInputStream 构造方法:

  1. ByteArrayInputStream(byte[] buf)
  • 使用给定的字节数组 buf 创建一个 ByteArrayInputStream


  1. ByteArrayInputStream(byte[] buf, int offset, int length)
  • 使用给定的字节数组 buf、偏移量 offset 和长度 length 创建一个 ByteArrayInputStream,表示从数组中的指定范围读取数据。


ByteArrayInputStream 方法摘要:

  1. int read()
  • 从输入流中读取下一个字节的数据。如果已经到达流的末尾,返回 -1。


  1. int read(byte[] b, int off, int len)
  • 从输入流中最多读取 len 个字节的数据到字节数组 b 中,从偏移量 off 开始存储。返回实际读取的字节数,如果已经到达流的末尾,返回 -1。


  1. long skip(long n)
  • 跳过输入流中的 n 个字节。返回实际跳过的字节数。


  1. int available()
  • 返回剩余可读取的字节数。


  1. void mark(int readlimit)
  • 在当前流位置设置标记,最多允许跳过 readlimit 个字节。


  1. void reset()
  • 将流的位置重置到最后一次调用 mark 方法设置的位置。


  1. boolean markSupported()
  • 判断此流是否支持 markreset 操作。


简单使用例子:

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 主要适用于以下一些场景:

  1. 测试和单元测试:
  • 在测试中,可能需要模拟一个输入流来测试某个类的输入处理逻辑。使用 ByteArrayInputStream 可以轻松创建一个包含测试数据的输入流,以便进行单元测试。

javaCopy code
byte[] testData = "Test data for unit testing.".getBytes();
InputStream testInputStream = new ByteArrayInputStream(testData);
// 使用 testInputStream 进行单元测试

  1. 内存数据读取:
  • 当有一个字节数组存储在内存中,并且需要将其作为输入流读取时,可以使用 ByteArrayInputStream

javaCopy code
byte[] memoryData = getMemoryData();
InputStream memoryInputStream = new ByteArrayInputStream(memoryData);
// 使用 memoryInputStream 读取内存数据

  1. 数据处理:
  • 在一些数据处理场景中,可能需要将字节数组中的数据通过输入流的方式传递给某个方法或组件。

javaCopy code
byte[] processData = getDataToProcess();
InputStream processInputStream = new ByteArrayInputStream(processData);
processData(processInputStream);

  1. 资源加载:
  • 在某些情况下,资源可能被加载到字节数组中,而不是从文件系统或网络中加载。ByteArrayInputStream 可以用于将这些字节数组包装成输入流,以便进行后续的处理。

javaCopy code
byte[] resourceData = loadResourceData();
InputStream resourceInputStream = new ByteArrayInputStream(resourceData);
// 对 resourceInputStream 进行进一步的处理

  1. 缓存处理:
  • 当一些缓存数据以字节数组形式存在时,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 封装这个字节数组。随后,通过 InputStreamread 方法逐字节读取数据,并将其转换为字符进行打印。最后,由于 ByteArrayInputStream 实现了 AutoCloseable 接口,我们使用 try-with-resources 语句确保输入流被正确关闭。

这个例子演示了如何使用 ByteArrayInputStream 将字节数组中的数据作为输入流进行读取,适用于一些需要处理字节数组数据的场景。

相关推荐

.NET 奇葩问题调试经历之3——使用了grpc通讯类库后,内存一直增长......

...

全局和隐式 using 指令详解(全局命令)

1.什么是全局和隐式using?在.NET6及更高版本中,Microsoft引入了...

请停止微服务,做好单体的模块化才是王道:Spring Modulith介绍

1、介绍模块化单体是一种架构风格,代码是根据模块的概念构成的。对于许多组织而言,模块化单体可能是一个很好的选择。它有助于保持一定程度的独立性,这有助于我们在需要的时候轻松过渡到微服务架构。Spri...

ASP.NET程序集引用之痛:版本冲突、依赖地狱等解析与实战

我是一位多年后端经验的工程师,其中前几年用ASP.NET...

.NET AOT 详解(.net 6 aot)

简介AOT(Ahead-Of-TimeCompilation)是一种将代码直接编译为机器码的技术,与传统的...

一款基于Yii2开发的免费商城系统(一款基于yii2开发的免费商城系统是什么)

哈喽,我是老鱼,一名致力于在技术道路上的终身学习者、实践者、分享者!...

asar归档解包(游戏arc文件解包)

要学习Electron逆向,首先要有一个Electron开发的程序的发布的包,这里就以其官方的electron-quick-start作为例子来进行一下逆向的过程。...

在PyCharm 中免费集成Amazon CodeWhisperer

CodeWhisperer是Amazon发布的一款免费的AI编程辅助小工具,可在你的集成开发环境(IDE)中生成实时单行或全函数代码建议,帮助你快速构建软件。简单来说,AmazonCodeWhi...

2014年最优秀JavaScript编辑器大盘点

1.WebstormWebStorm是一种轻量级的、功能强大的IDE,为Node.js复杂的客户端开发和服务器端开发提供完美的解决方案。WebStorm的智能代码编辑器支持JavaScript,...

基于springboot、tio、oauth2.0前端vuede 超轻量级聊天软件分享

项目简介:基于JS的超轻量级聊天软件。前端:vue、iview、electron实现的PC桌面版聊天程序,主要适用于私有云项目内部聊天,企业内部管理通讯等功能,主要通讯协议websocket。支持...

JetBrains Toolbox推出全新产品订阅授权模式

捷克知名软件开发公司JetBrains最为人所熟知的产品是Java编程语言开发撰写时所用的集成开发环境IntelliJIDEA,相信很多开发者都有所了解。而近期自2015年11月2日起,JetBr...

idea最新激活jetbrains-agent.jar包,亲测有效

这里分享一个2019.3.3版本的jetbrains-agent.jar,亲测有效,在网上找了很多都不能使用,终于找到一个可以使用的了,这里分享一下具体激活步骤,此方法适用于Jebrains家所有产品...

CountDownTimer的理解(countdowntomars)

CountDownTimer是android开发常用的计时类,按照注释中的说明使用方法如下:kotlin:object:CountDownTimer(30000,1000){...

反射为什么性能会很慢?(反射时为什么会越来越长)

1.背景前段时间维护一个5、6年前的项目,项目总是在某些功能使用上不尽人意,性能上总是差一些,仔细过了一下代码发现使用了不少封装好的工具类,工具类里面用了好多的反射,反射会影响到执行效率吗?盲猜了一...

btrace 开源!基于 Systrace 高性能 Trace 工具

介绍btrace(又名RheaTrace)是抖音基础技术团队自研的一款高性能AndroidTrace工具,它基于Systrace实现,并针对Systrace不足之处加以改进,核心改进...

取消回复欢迎 发表评论: