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

相关推荐
向着光芒的女孩19 小时前
【IDEA】关不了的Proxy Authentication弹框探索过程
java·ide·intellij-idea
Filotimo_20 小时前
Spring Boot 整合 JdbcTemplate(持久层)
java·spring boot·后端
智商低情商凑20 小时前
Go学习之 - Goroutines和channels
开发语言·学习·golang
半桶水专家20 小时前
Go 语言时间处理(time 包)详解
开发语言·后端·golang
编程点滴20 小时前
Go 重试机制终极指南:基于 go-retry 打造可靠容错系统
开发语言·后端·golang
李慕婉学姐20 小时前
【开题答辩过程】以《“饭否”食材搭配指南小程序的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·spring·小程序
实心儿儿20 小时前
C++ —— 模板进阶
开发语言·c++
萧鼎21 小时前
Python PyTesseract OCR :从基础到项目实战
开发语言·python·ocr
abments21 小时前
pgsql timestamp without time zone > character varying解决方案
java
二川bro21 小时前
第57节:Three.js企业级应用架构
开发语言·javascript·架构