背景:前面有提到字节输入输出流,当读取文件文本使用字节,但中文都是由两个或者三个字节组成的,如果字节读取长度没设置好,很容易造成乱码
Reader 是字符输入流的抽象父类,提供了
read 一次读取一个字符
read(char[] cbuf) 一次读取多个字符到字符缓冲区cbuf,返回长度表示读取的字符个数。
FileReader 文件字符输入流,专门用于读取默认字符编码文本性文件。
public static void main(String[] args) throws IOException { File file=new File("D:\\111\\a.txt"); //管道 FileReader reader=new FileReader(file); //一次读取多个字符(字符数组或者字符串) char[]cbuf=new char[2]; int len; StringBuilder sb=new StringBuilder(); while ((len=reader.read(cbuf))!=-1) { sb.append(cbuf,0,len); } System.out.println(sb);
reader.close(); }
Writer 是字符输出流的抽象父类,提供了
write
write(char[] cbuf)
write(string)
FileWriter 文件字符输出流,专门用于写入默认字符编码的文本性文件。为了提高效率,FileWriter内部存在一个字节缓冲区,用于对待写入的字符进行统一编码到字节缓冲区,一定要在关闭流之前,调用flush方法刷新缓冲区
public static void main(String[] args) throws IOException { File file=new File("D:\\111\\a.txt"); //管道 FileWriter writer=new FileWriter(file); //写入字符串 String str="你好中国"; writer.write(str); writer.flush(); writer.close(); }