
java基础:12.5 缓存流 BufferReader、 PrintWriter、flush
发布日期:2022-04-04 06:36:29
浏览次数:2
分类:博客文章
本文共 1537 字,大约阅读时间需要 5 分钟。
1. Review
上两节学过的字节流和字符流,其弊端是在每一次读写的时候,都会访问硬盘。 如果读写的频率比较高的时候,其性能表现不佳。
为了解决以上弊端,采用缓存流
。 缓存流在读取的时候,会一次性读较多的数据到缓存中
,以后每一次的读取,都是在缓存中访问,直到缓存中的数据读取完毕,再到硬盘中读取
。
缓存流在写入数据的时候,会先把数据写入到缓存区,直到缓存区达到一定的量,才把这些数据,一起写入到硬盘中去。按照这种操作模式,就不会像字节流,字符流那样每写一个字节都访问硬盘,从而减少了IO操作
key word: BufferReader
、 PrintWriter
、flush
2. BufferReader、 PrintWriter
package stream; import java.io.BufferedReader;import java.io.File;import java.io.FileReader;import java.io.FileWriter;import java.io.IOException;import java.io.PrintWriter; public class Main {
public static void main(String[] args) {
File f1 = new File("f:/testfile/test.txt");
// 创建文件字符流
// 缓存流[必须]建立在一个存在的流的基础上
try (
FileReader fr = new FileReader(f1);
BufferedReader br = new BufferedReader(fr);
)
{
while (true) {
// 一次读一行
String line = br.readLine();
if (null == line)
break;
System.out.println(line);
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
File f2 = new File("f:/testfile/file.txt");
try (
FileWriter fw = new FileWriter(f2);
PrintWriter pw = new PrintWriter(fw);
){
pw.println("今天");
pw.println("是一个");
pw.println("好日子");
}
catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}}
3. flush
当操作要要立即把数据写入到硬盘,而不是等缓存满了才写出去时,适用flush
把上一节的程序改写成
File f2 = new File("f:/testfile/file.txt");
try (
FileWriter fw = new FileWriter(f2);
PrintWriter pw = new PrintWriter(fw);
){
pw.println("今天");
pw.flush();
pw.println("是一个");
pw.flush();
pw.println("好日子");
}
catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
转载地址:https://www.cnblogs.com/l20902/p/10610883.html 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
路过按个爪印,很不错,赞一个!
[***.249.68.14]2022年05月22日 13时39分42秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
最新文章
Shiro-HelloWord
2019-05-09 08:49:12
kafka系列之(3)——Coordinator与offset管理和Consumer Rebalance
2019-05-09 08:49:12
storm-kafka源码走读之KafkaSpout
2019-05-09 08:49:11
apache kafka系列之在zookeeper中存储结构
2019-05-09 08:49:11
Kafka源码深度解析-序列7 -Consumer -coordinator协议与heartbeat实现原理
2019-05-09 08:49:10
Kafka设计解析(一)- Kafka背景及架构介绍
2019-05-09 08:49:09
Java transient关键字使用小记
2019-05-09 08:49:09
Storm开发过程中的问题与建议
2019-05-09 08:49:08
Kafka 0.9+Zookeeper3.4.6集群搭建、配置,新Client API的使用要点,高可用性测试,以及各种坑 (转载)...
2019-05-09 08:49:08
oracle查看允许的最大连接数和当前连接数等信息
2019-05-09 08:49:07
HDFS常用的Java Api详解
2019-05-09 08:49:07
java多线程并发去调用一个类的静态方法安全性探讨
2019-05-09 08:49:06
Hdfs详解
2019-05-09 08:49:05
Jenkins之构建触发器配置(转载)
2019-05-09 08:49:05
HDFS超租约异常总结(org.apache.hadoop.hdfs.server.namenode.LeaseExpiredException)
2019-05-09 08:49:04
Spring MVC配置文件的三个常用配置详解
2019-05-09 08:49:04
Storm实时计算:流操作入门编程实践
2019-05-09 08:49:03
【intellij idea】Project Structure 讲解
2019-05-09 08:49:03
Oracle hash分区的秘密
2019-05-09 08:49:02
Servlet 3.0 新特性详解
2019-05-09 08:49:02