java里的i/o流

在Java中,I/O(输入/输出)流是用于处理输入和输出操作的抽象概念。Java的I/O库提供了许多类和方法,用于从各种来源(如文件、网络、内存等)读取数据(输入流),以及将数据写入到各种目标(如文件、网络、内存等)中(输出流)。

Java的I/O流大致可以分为以下几种类型:

  1. 字节流(Byte Streams)

    • 字节输入流:InputStream
    • 字节输出流:OutputStream

    这些流用于处理原始字节数据。FileInputStreamFileOutputStream 是常见的用于文件操作的字节流。

  2. 字符流(Character Streams)

    • 字符输入流:Reader
    • 字符输出流:Writer

    这些流用于处理字符数据,它们内部使用特定的字符集(如UTF-8)将字节转换为字符或将字符转换为字节。FileReaderFileWriterBufferedReaderBufferedWriter 是常见的字符流。

  3. 缓冲流(Buffered Streams)

    • 缓冲字节流:BufferedInputStreamBufferedOutputStream
    • 缓冲字符流:BufferedReaderBufferedWriter

    缓冲流提供了一种增加输入/输出性能的方法,因为它们将数据存储在内部缓冲区中,减少了与底层I/O设备的交互次数。

  4. 转换流(Conversion Streams)

    • InputStreamReaderOutputStreamWriter 是用于字节流和字符流之间转换的桥梁。它们使用指定的字符集(如UTF-8)将字节转换为字符或将字符转换为字节。
  5. 其他特定类型的流

    • ObjectInputStreamObjectOutputStream 用于对象的序列化和反序列化。
    • DataInputStreamDataOutputStream 提供了对基本数据类型(如intdoubleString等)进行高效输入/输出的功能。
    • PrintStreamPrintWriter 提供了方便的打印和格式化输出功能。
  6. 节点流(Node Streams)处理流(Processing Streams)

    • 节点流(或低级流)直接连接到数据源或目标,如FileInputStreamFileOutputStream
    • 处理流(或高级流)是"连接"到已存在的节点流上为数据提供额外功能的流,如BufferedReaderBufferedWriter

在实际应用中,通常会组合使用这些流来满足特定的I/O需求。例如,当你需要从文件中按行读取文本时,你可能会使用FileInputStreamInputStreamReader结合BufferedReader来创建一个可以高效读取文本的流。

相关推荐
Nyarlathotep011316 小时前
SpringBoot Starter的用法以及原理
java·spring boot
wuwen516 小时前
WebFlux + Lettuce Reactive 中 SkyWalking 链路上下文丢失的修复实践
java
SimonKing16 小时前
GitHub 10万星的OpenCode,正在悄悄改变我们的工作流
java·后端·程序员
Seven9717 小时前
虚拟线程深度解析:轻量并发编程的未来趋势
java
雨中飘荡的记忆1 天前
ElasticJob分布式调度从入门到实战
java·后端
考虑考虑1 天前
JDK25模块导入声明
java·后端·java ee
_小马快跑_2 天前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Re_zero2 天前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记2 天前
Spring Boot条件注解详解
java·spring boot
程序员清风2 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试