字节缓冲流

简介: 字节缓冲流

字节缓冲流(Byte Buffered Stream)是 Java 中用于提高字节输入/输出效率的流对象。它通过在内存中创建一个缓冲区(Buffer)来减少与底层输入/输出流的交互次数,从而提高读写操作的性能。

在 Java 中,主要使用 java.io.BufferedInputStreamjava.io.BufferedOutputStream 类来实现字节缓冲流的功能。

以下是两个常见的字节缓冲流类及其示例用法:

  1. BufferedInputStream 在读取字节数据时提供了缓冲和一次读取多个字节的功能。
import java.io.BufferedInputStream;
import java.io.FileInputStream;
import java.io.IOException;
try (BufferedInputStream bis = new BufferedInputStream(new FileInputStream("input.txt"))) {
    byte[] buffer = new byte[1024];
    int bytesRead;
    while ((bytesRead = bis.read(buffer)) != -1) {
        // 对读取到的字节数据进行处理
    }
} catch (IOException e) {
    e.printStackTrace();
}
  1. 在上述示例中,创建了一个 BufferedInputStream 对象,并传入一个底层的 FileInputStream 来读取文件数据。使用一个字节数组作为缓冲区,调用 read(byte[]) 方法一次性读取多个字节数据,将读取到的字节数存储在 bytesRead 变量中,然后可以对读取到的字节数据进行处理。
  2. BufferedOutputStream 在写入字节数据时提供了缓冲和一次写入多个字节的功能。
import java.io.BufferedOutputStream;
import java.io.FileOutputStream;
import java.io.IOException;
try (BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream("output.txt"))) {
    byte[] data = "Hello, World!".getBytes();
    bos.write(data);
} catch (IOException e) {
    e.printStackTrace();
}
  1. 在上述示例中,创建了一个 BufferedOutputStream 对象,并传入一个底层的 FileOutputStream 来写入文件数据。通过调用 write(byte[]) 方法一次性写入多个字节数据,将字节数组中的数据写入到缓冲区,然后根据情况将缓冲区的数据刷新到底层输出流中。
    使用字节缓冲流可以提高读写操作的效率,减少与底层输入/输出流的交互次数。同时,为了确保资源的正确关闭,在示例中使用了 Java 7 引入的 try-with-resources 语句来自动关闭字节缓冲流对象。

原理 :

 

假设我们要从硬盘上的文件中读取数据,并将其存储到内存中。如果直接使用底层的输入流(如FileInputStream),每次读取一个字节,那么每个读取操作都会引发一次磁盘访问,从而增加磁盘IO的开销。

而使用字节缓冲流(BufferedInputStream)则不同。它在底层输入流和应用程序之间创建了一个缓冲区,并以块的形式从输入流中读取数据。这样,每次读取的不再是一个字节,而是一块数据,例如一个字节数组。

当应用程序需要从缓冲区中读取数据时,字节缓冲流会立即从底层输入流中填充缓冲区。这样,相较于每次都进行磁盘访问,我们可以通过一次读取多个字节,减少了磁盘IO的次数,从而提高了读取的效率。

类似地,字节缓冲流的写入操作也是如此。它将输出数据暂存在缓冲区中,当缓冲区满了或达到了一定条件时,才会将缓冲区中的数据一次性写入到底层输出流中,从而减少了频繁的写入操作。

通过使用字节缓冲流,在内存和磁盘之间引入了一个缓冲区,以减少IO访问的次数,从而提高读取和写入操作的效率。这种缓冲机制能够充分利用计算机内存的高速读写能力,达到优化IO操作的目的。

 


相关文章
|
9月前
|
传感器 物联网 大数据
物联网与大数据:揭秘万物互联的新纪元
物联网与大数据:揭秘万物互联的新纪元
361 7
|
JavaScript 前端开发 API
网络请求库 – axios库
网络请求库 – axios库
426 60
|
开发框架 JSON 缓存
基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理
基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理
|
开发框架 数据库 开发者
OOP有哪些应用场景
【7月更文挑战第17天】OOP有哪些应用场景
395 3
|
存储 Java 数据库
【微服务系列笔记】微服务概述
本文对比了单体应用和微服务架构。单体应用中所有功能模块在一个工程中,而微服务则按领域模型拆分为独立服务,每个服务有明确边界,可独立开发、部署和扩展。微服务允许使用不同语言和技术栈,每个服务有自己的数据库。微服务架构的优点包括易于开发维护、技术栈开放和错误隔离,但缺点包括增加运维成本、调用链路复杂、分布式事务处理困难以及学习成本高。实现微服务通常涉及SpringCloud等开发框架和Docker等运行平台。
360 2
|
Web App开发 数据采集 JavaScript
Node.js
【10月更文挑战第14天】
225 18
|
存储 安全 芯片
阿里云网盘与相册问题之MAC电脑是否支持挂载盘
阿里云网盘与相册是阿里云提供的云存储服务,用户可以安全便捷地存储和管理个人文件、照片等数据;本合集将介绍如何使用阿里云网盘和相册服务,包括文件上传、同步、分享,以及处理常见使用问题的技巧。
404 1
|
缓存 Java 数据库连接
mybatis1.常见配置
本文介绍了MyBatis框架中的常见配置及其加载顺序。配置可通过`properties`元素、资源文件或方法参数传递,其中方法参数传递的属性具有最高优先级。文章列举了几个重要的配置项,如`cacheEnabled`用于全局开启或关闭缓存功能;`lazyLoadingEnabled`控制对象的延迟加载行为;`useGeneratedKeys`允许JDBC支持自动生成主键;`defaultExecutorType`设定默认执行器类型等。此外,还介绍了多环境配置方法,通过`environments`元素可定义不同环境下的数据库连接信息,并可根据需求动态选择加载特定环境
|
开发工具 开发者
一些与做游戏有关的你想知道的事
我始终认为做游戏是一项技能,游戏创作者制作一个游戏,跟写作者写一篇文章,吉他手弹一首乐曲,糕点师做一个松软的面包,木匠做一套精美的家具都是一样的。对于掌握一项技能来讲,只有一件最重要的事,就是熟练。所以,想学好做游戏唯有不停的练习直至熟练,除此之外,其它的都是弯路。
265 0

热门文章

最新文章