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操作。

原因:减少系统调用

相关推荐
Gain_chance1 小时前
36-学习笔记尚硅谷数仓搭建-DWS层数据装载脚本
大数据·数据仓库·笔记·学习
肖永威1 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos
暗光之痕2 小时前
Unreal5研究笔记 Actor的生命周期函数
笔记·unreal engine
Gain_chance2 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
宵时待雨3 小时前
STM32笔记归纳9:定时器
笔记·stm32·单片机·嵌入式硬件
m0_719084113 小时前
React笔记张天禹
前端·笔记·react.js
r i c k6 小时前
数据库系统学习笔记
数据库·笔记·学习
shandianchengzi7 小时前
【小白向】错位排列|图文解释公考常见题目错位排列的递推式Dn=(n-1)(Dn-2+Dn-1)推导方式
笔记·算法·公考·递推·排列·考公
浅念-7 小时前
C语言编译与链接全流程:从源码到可执行程序的幕后之旅
c语言·开发语言·数据结构·经验分享·笔记·学习·算法
The森7 小时前
Linux IO 模型纵深解析 01:从 Unix 传统到 Linux 内核的 IO 第一性原理
linux·服务器·c语言·经验分享·笔记·unix