package com.io.e_character;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileReader;
import java.io.IOException;
import org.junit.Test;
/*
字节流:字节流读取的是文件中的二进制数据,读到的数据并不会转换成我们能看得懂的字符;
字符流:字符流会把读到的二进制的数据进行对应的编码与解码工作;字符流 = 字节流 + 编码(解码);
输入字符流:
------| Reader:输入字符流的基类;抽象类;
---------| FileReader:读取文件的输入字符流;
FileReader的使用步骤:
1、找到目标文件
2、建立数据的输入通道
3、读取数据
4、关闭资源
*/
public class Demo1 {
// 使用FileReader读取文件数据
@Test
public void test1() throws IOException{
// 1、找到目标文件
File file = new File("D:\\a.txt");
// 2、建立数据的输入通道
FileReader reader = new FileReader(file);
// 3、读取数据
int content = 0;
// 根据读取到的数字查找GBK码表,找到对应的字符;每次读取一个字符,效率低;
while ((content = reader.read()) != -1){
System.out.print((char)content);
}
// 4、关闭资源
reader.close();
}
// 使用缓冲字符数组读取文件数据
@Test
public void test2() throws IOException{
// 找到目标文件
File file = new File("D:\\a.txt");
// 建立数据输入通道
FileReader reader = new FileReader(file);
// 建立字符缓冲数据,读取文件数据
int len = 0;
char[] buf = new char[1024];
while ((len = reader.read(buf)) != -1){
System.out.print(new String(buf, 0, len));
}
// 是否资源
reader.close();
}
// 问题:既然使用字节流也可以读取中文数据,为什么还要使用字符流读取?
// 因为使用字节流读取中文数据是存在隐患的,有可能会出现乱码;如下例子所示;
@Test
public void test3() throws IOException{
// 找到目标文件
File file = new File("D:\\a.txt");
// 建立数据输入通道
FileInputStream in = new FileInputStream(file);
// 读取数据:此处之所以能正常读取数据,是因为缓冲数组足够大
int len = 0;
byte[] buf = new byte[1024];
while ((len = in.read(buf)) != -1){
// 使用字节流之所以能读取中文数据,实际上是借助了字符串的解码功能;
System.out.print(new String(buf, 0, len));
}
// 关闭资源
in.close();
System.out.println("");
// 如果下面情况,就会读取出乱码:a.txt文件中存储的数据是:你好a中国
FileInputStream input = new FileInputStream(file);
byte[] buff = new byte[2];
len = 0;
while ((len = input.read(buff)) != -1){
// 输出结果:你好a?泄?
// 因为中文数据占两个字节,英文数据占一个字节,当读取数据的时候,一次读取的字节数据刚好读取了中文数据的一半,
// 那么此时解码出来的数据就是乱码;所以读取中文数据时最好使用 字符流;
System.out.print(new String(buff, 0, len));
}
input.close();
}
}
Java学习笔记之IO(七):FileReader输入字符流
最新推荐文章于 2022-05-26 21:08:13 发布