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

相关推荐
PyAIGCMaster几秒前
50周学习go语言:第四周 函数与错误处理深度解析
开发语言·学习·golang
全栈开发圈1 分钟前
新书速览|Rust汽车电子开发实践
开发语言·rust·汽车
PyAIGCMaster3 分钟前
第二周补充:Go语言中&取地址符与fmt函数详解
开发语言·后端·golang
刘什么洋啊Zz7 分钟前
剖析IO原理和零拷贝机制
java·运维·网络
~kiss~8 分钟前
Rust学习~tokio简介
开发语言·学习·rust
卷心菜好6啊15 分钟前
特辣的海藻!2
java
心态与习惯18 分钟前
mac 下 java 调用 gurobi 不能加载 jar
java·jar·mac·cplex·gurobi
he2581919 分钟前
centOS 7.9 安装JDK MYSQL
java·mysql·centos
Mr.Wang80921 分钟前
条款23:宁以non-member、non-friend替换member函数
开发语言·c++
找了一圈尾巴31 分钟前
Spring Boot 日志管理(官网文档解读)
java·spring boot