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来创建一个可以高效读取文本的流。

相关推荐
咖啡教室4 小时前
java日常开发笔记和开发问题记录
java
咖啡教室4 小时前
java练习项目记录笔记
java
鱼樱前端5 小时前
maven的基础安装和使用--mac/window版本
java·后端
RainbowSea5 小时前
6. RabbitMQ 死信队列的详细操作编写
java·消息队列·rabbitmq
RainbowSea5 小时前
5. RabbitMQ 消息队列中 Exchanges(交换机) 的详细说明
java·消息队列·rabbitmq
我不会编程5557 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
李少兄7 小时前
Unirest:优雅的Java HTTP客户端库
java·开发语言·http
此木|西贝7 小时前
【设计模式】原型模式
java·设计模式·原型模式
可乐加.糖7 小时前
一篇关于Netty相关的梳理总结
java·后端·网络协议·netty·信息与通信
无名之逆7 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust