java IO流之BufferedReader和BufferedWriter[通俗易懂]

java IO流之BufferedReader和BufferedWriter[通俗易懂]笑霸能看懂的学习笔记

大家好,又见面了,我是你们的朋友全栈君。

前言
?作者简介:我是笑霸final,一名热爱技术的在校学生。
?个人主页:笑霸final的主页
?系列专栏::本文写在java专栏
?如果文章知识点有错误的地方,请指正!和大家一起学习,一起进步?
?如果感觉博主的文章还不错的话,?点赞? + ?关注? + ?收藏?

一、简介:

BufferedReader 用于加快读取字符的速度, BufferedWriter 用于加快写入的速度 BufferedReader 和 BufferedWriter 类各拥有 8192 个字符的缓冲区。
属于字符流,按照字符读取数据的

二、使用BufferedReader案列

1.使用它读取文本文件,并显示在控制台
步骤;
1.创建读取的文件
2.创建BufferedReader
3.读取
4.关闭流

package com.xbfinal.day02;

import java.io.BufferedReader;
import java.io.FileReader;


/** *演示BufferedReader的使用 * */
public class BufferedReader_ { 
   
	public static void main(String[] args) throws Exception{ 
   
		
		//1.创建读取的文件
		String filePath="f:\\01.txt";
		//2.创建BufferedReader
		BufferedReader buf=new BufferedReader(new FileReader(filePath));
		//读取(其实底层是FileReader)
		String line;
		//按行读取文件,当返回null表示文件读取完毕
		while((line=buf.readLine())!=null) { 
   
			System.out.println(line);
		}
		//关闭流(本身应该关闭FileReader 但是实际上只需要关闭BufferedReader)
		buf.close();//底层会自动关闭节点流
		
	}

}

在这里插入图片描述

可见上面代码中文乱码了
bufferedReader会以系统默认的编码字符集获取文件内容。如果解析设置的编码字符集与系统默认编码字符集不一致,则会出现乱码问题。

BufferedReader 中文乱码解决方案解决方案;

BufferedReader buf=new BufferedReader(new FileReader(filePath));
换成
InputStreamReader isr = new InputStreamReader(new FileInputStream(filePath), "UTF-8");
		BufferedReader buf=new BufferedReader(isr);

效果:

package com.xbfinal.day02;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.InputStreamReader;


/** *演示BufferedReader的使用 * */
public class BufferedReader_ { 
   
	public static void main(String[] args) throws Exception{ 
   
		
		//1.创建读取的文件
		String filePath="f:\\01.txt";
		//2.创建BufferedReader
		InputStreamReader isr = new InputStreamReader(new FileInputStream(filePath), "UTF-8");
		BufferedReader buf=new BufferedReader(isr);
		//读取(其实底层是FileReader)
		String line;
		//按行读取文件,当返回null表示文件读取完毕
		while((line=buf.readLine())!=null) { 
   
			System.out.println(line);
		}
		//关闭流(本身应该关闭FileReader 但是实际上只需要关闭BufferedReader)
		buf.close();//底层会自动关闭节点流
		
	}

}

在这里插入图片描述

三、BufferedWriter使用案例

在这里插入图片描述

hello,笑霸final写入文件
步骤
1.文件写入的路径
2.创建对象
3.写入内容
4.关闭流对象

package com.xbfinal.day02;

import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;

//演示BufferedWriter的使用

public class BufferedWriter_ { 
   
	public static void main(String[] args)throws IOException { 
   
		//文件写入的路径
		String filePath="f:\\xbfinal.txt";
		//准备写入的内容
		BufferedWriter buf=new BufferedWriter(new FileWriter(filePath));
		buf.write("hello,笑霸final");
		buf.newLine();//插入一个换行符;
		buf.write("hello1,笑霸final");
		buf.write("hello2,笑霸final");
		buf.close();
		
	}

}

在这里插入图片描述

追加代码
改动一个地方

BufferedWriter buf=new BufferedWriter(new FileWriter(filePath,true));

然后就能完成追加了
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137376.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • resharper激活码(最新序列号破解)

    resharper激活码(最新序列号破解),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月20日
    283
  • C语言malloc函数的功能及用法

    C语言malloc函数的功能及用法关于C语言malloc函数函数介绍应用举例1应用举例2函数介绍malloc(memoryallocation) 中文名称:动态内存分配用于申请一块连续的指定大小的内存块区域以void*类型返回分配的内存区域地址,当无法知道内存具体位置的时候,想要绑定真正的内存空间,就需要用到动态的分配内存。应用举例1关于C语言动态申请数组(整形数据类型)空间的应用#include<stdio…

    2022年6月9日
    38
  • 如何在java中输出保留两位小数「建议收藏」

    如何在java中输出保留两位小数「建议收藏」在输出时用以下的代码:System.out.println(String.format(“%.2f”,sum));其中”%.2f”为保留两位小数,sum为要输出的数字。当然,用print输出也是可以的:System.out.print(String.format(“%.2f”,sum));…

    2022年7月7日
    77
  • Linux学习—vim文本编辑器学习

    1 VIM编辑器概述 什么是vi:可视化接口(Visual Interface). vi————> vim 升级那些提升!支持多级撤销 u跨平台运行语法高亮支持图形界面

    2022年2月26日
    39
  • apache安装教程详解_Apache安装

    apache安装教程详解_Apache安装1.Apache安装1.下载apache下载链接2.将解压文件移动到目标目录(整个文件目录最好用英文不要有空格)3.命令行注册apache服务(不同于exe文件的安装)(以管理员身份打开cmdwin10)(管理员身份和普通用户身份区别)(在命令行中找到目标httpd.exe文件目录输入cdC:\wamp\Apache24\bin…

    2022年9月21日
    0
  • 算法时间复杂度的计算

    算法时间复杂度的计算一、算法时间复杂度定义在进行算法分析时候,语句总的执行次数T(n)是关于问题规模n的函数,进而分型T(n)随着n的变化情况并确定T(n)的数量级.算法的时间复杂度,也就是算法的时间度量记作:T(n)=O(f(n)).它表示随着问题规模n的增大,算法执行时间的增长率和f(n)的增长率相同,称作算法的渐近时间复杂度,简称时间复杂度.其中f(n)是问题规模n的某个函数.简单来说T…

    2022年5月14日
    49

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号