IO
IO
所有输入流的基类:InputStream / Reader
所有输出流的基类:OutputStream / Writer
字节流
InputStream
常用方法:read(), skip(), available(), close()
-
FileInputStream
-
DataInputStream
: 用于读取指定类型数据,不能单独使用,必须结合其它流,比如FileInputStream
。 -
ObjectInputStream
: 从输入流中读取 Java 对象(反序列化) -
BufferedInputStream
OutputStream
常用方法:write(), flush(), close()
-
FileOutputStream
-
DataOutputStream
-
ObjectOutputStream
: 将对象写入到输出流 (序列化)。 -
BufferedOutputStream
常用字符编码所占字节数?utf8
:英文占 1 字节,中文占 3 字节,unicode
:任何字符都占 2 个字节,gbk
:英文占 1 字节,中文占 2 字节。
字符流
Reader(字符输入流)
Reader
用于读取文本, InputStream
用于读取原始字节。
Reader
常用方法:read(), skip(), close()
字节流转换为字符流的桥梁:InputStreamReader
// 字节流转换为字符流的桥梁
public class InputStreamReader extends Reader {
}
// 用于读取字符文件
public class FileReader extends InputStreamReader {
}
Writer(字符输出流)
Writer
用于将数据(字符信息)写入到目的地(通常是文件)Writer
常用方法:write(), append(), flush(), close()
字符流转换为字节流的桥梁:OutputStreamWriter
// 字符流转换为字节流的桥梁
public class OutputStreamWriter extends Writer {
}
// 用于写入字符到文件
public class FileWriter extends OutputStreamWriter {
}
字节缓冲流
BufferedInputStream
BufferedOutputStream
字节缓冲流会先将读取到的字节存放在缓存区,大幅减少 IO 次数,提高读取效率。
字符缓冲流
BufferedReader
BufferedWriter
打印流
PrintStream
PrintWriter
IO模型
BIO (Blocking I/O)同步阻塞IO模型
应用程序发起 read 调用后,会一直阻塞,直到内核把数据拷贝到用户空间。
NIO (Non-blocking/New I/O)
同步非阻塞 IO 模型:应用程序会一直发起 read 调用,等待数据从内核空间拷贝到用户空间的这段时间里,线程依然是阻塞的,直到在内核把数据拷贝到用户空间。(通过轮询操作,避免了一直阻塞。)
-
NIO 面向块,I/O 面向流
-
非阻塞、面向缓冲、基于通道的 I/O,可以使用少量的线程来处理多个连接,大大提高了 I/O 效率和并发。
NIO核心组件:
-
Buffer(缓冲区)
-
Channel(通道):双向的、可读可写的数据传输通道
-
Selector(选择器)
NIO零拷贝:零拷贝是指计算机执行 IO 操作时,CPU 不需要将数据从一个存储区域复制到另一个存储区域,从而可以减少上下文切换以及 CPU 的拷贝时间。
AIO (Asynchronous I/O)
异步 IO 模型:异步 IO 是基于事件和回调机制实现的,也就是应用操作之后会直接返回,不会堵塞在那里,当后台处理完成,操作系统会通知相应的线程进行后续的操作。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构