FileReader文件字符输入流

一.构造器

public FileReader(File file)创建字符输入流管道与源文件接通


public FileReader(String pathname)创建字符输入流管道与源文件接通

二.方法

public int read()每次读取一个字符返回,如果发现没有数据可读会返回-1.

public int read(char【】buffer)每次用一个字符数组去读取数据,返回字符数组读取了多少个字符,如果发现没有数据可读会返回-1.

三.代码

package org.example;

import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.io.Reader;

public class day06 {
    public static void main(String[] args) {
        try (
            Reader fr = new FileReader("d:/temp/day05/test.txt")
        ){
            //读取内容
            int c;
            while((c = fr.read())!= -1){
                System.out.print((char)c);
            }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
}

四.结果

五.优化

1.代码

package org.example;

import java.io.FileReader;
import java.io.Reader;

public class day06 {
    public static void main(String[] args) {
        try (
            Reader fr = new FileReader("d:/temp/day05/test.txt")
        ){
            //每次读取多个字符
             char[] buffer = new char[5];
             int len;
             while((len = fr.read(buffer)) != -1){
                 System.out.print(new String(buffer,0,len));
             }
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
}

2.结果

在处理中文字符时,出现乱码的问题通常是由于编码和解码的方式不匹配导致的。在Java中,使用字符输入流(如FileReader、BufferedReader等)可以解决中文乱码问题,主要原因如下:

  1. 字符输入流默认使用UTF-8编码读取文件:UTF-8是一种可变长度的编码方式,可以表示世界上几乎所有的书写语言。使用字符输入流读取文件时,它会默认使用UTF-8编码对文件进行解码,从而正确地解析中文字符。
  2. 字符输入流支持解码各种字符集:字符输入流可以解码多种字符集,包括UTF-8、GBK等。这样,无论文件使用何种编码方式,都可以通过字符输入流正确地读取和解析。
  3. 字符输入流提供方便的接口:字符输入流提供了方便的接口用于读取文件中的字符数据,避免了字节流读取数据时需要进行编码转换的麻烦。

因此,在使用Java处理中文字符时,推荐使用字符输入流来读取文件中的数据,这样可以避免乱码问题的出现。当然,如果需要写入文件时,也需要使用相应的字符输出流(如FileWriter、BufferedWriter等)来将字符数据写入文件,并使用正确的编码方式进行编码。

你可能感兴趣的:(java,字符输入流,FileReader)