IO流笔记

Java中的IO操作大体能分成两种:输出流和输入流,根据使用的流的方式,又可分为字符流和字节流。

1.读数据流

Reader和InputStream,它们都是抽象类,必须由其子类实例化。

实例化:FileReader和FileInputStream,其构造方法中传入路径参数。
方法:

read();每次读取一个字节/字符

read(char []/byte []);每次读取一群字节/字符,需要提供一个"桶"来装数据

2.写数据流

Writer和OutStream

实例化:FileWriter和FileOutStream
方法:

write():写入,写入的数据可以是一个/一群字符/字节

3. 缓冲流包装

使用缓冲流包装可以显著提高读写速度。

原因:在Java中,进行文件IO操作需要jvm通过系统调用实现内存中程序的数据与磁盘的交互。在这个过程中系统调用的次数越多耗时越大。缓冲流通过在内存中提供一个8KB的缓冲区实现降低系统调用的次数从而提升IO的速度。

方法:

java 复制代码
Reader reader = new FileReader("");
BufferedReader bufferedReader = new BufferedReader(reader);

InputStream inputStream = new FileInputStream("");
BufferedInputStream bufferedInputStream = new BufferedInputStream(inputStream);

Writer fileWriter = new FileWriter("");
BufferedWriter bufferedWriter = new BufferedWriter(fileWriter);

FileOutputStream fileOutputStream = new FileOutputStream("");
BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(fileOutputStream)

4.性能

通过实践,发现当提供的"桶"容量越大,IO速度越快,但最终会趋于一个理想恒定值(再加大容量也不会显著提升),基于这一点,一个一个的字节/字符进行IO操作其效率非常慢故被抛弃,所以常使用缓冲流包装+较大的"桶"容量来实现IO操作。

原因:减少系统调用

相关推荐
丝斯201111 小时前
AI学习笔记整理(42)——NLP之大规模预训练模型Transformer
人工智能·笔记·学习
凉、介13 小时前
深入 QEMU Guest Agent:虚拟机内外通信的隐形纽带
c语言·笔记·学习·嵌入式·虚拟化
njsgcs14 小时前
SIMA2 论文阅读 Google 任务设定器、智能体、奖励模型
人工智能·笔记
云半S一15 小时前
pytest的学习过程
经验分享·笔记·学习·pytest
AI视觉网奇15 小时前
ue5.7 配置 audio2face
笔记·ue5
崎岖Qiu17 小时前
【OS笔记35】:文件系统的使用、实现与管理
笔记·操作系统·存储管理·文件系统·os
曦月逸霜18 小时前
离散数学-学习笔记(持续更新中~)
笔记·学习·离散数学
hunter145018 小时前
windows server AD域与CA部署证书
笔记
im_AMBER18 小时前
Leetcode 101 对链表进行插入排序
数据结构·笔记·学习·算法·leetcode·排序算法
laplace012318 小时前
# 第四章|智能体经典范式构建 —— 学习笔记(详细版)
笔记·学习