出现此问题的原因:文件的编码,系统的编码,java的默认编码有冲突。
假如我们用FileReader这些类来读取系统文件,它调用的字符编码是java默认的UTF-8,但是一般WINDOW的TXT默认是ANSI,而自己本机的中文编码是GBK
所以读取数据就会出现代码,示例代码如下:
BufferedReader reader = new BufferedReader(new FileReader(file));
因为这是编码问题,所以就要转换字符编码,但FileReader构造函数和方法成员都没有设置编码方法
而InputStreamReader这个类有,因此可以wrap它以来达到转换字符编码的目的,代码如下:
BufferedReader reader = new BufferedReader(new InputStreamReader(new FileInputStream(file),"GBK"));
这样转换之后就可以正常读取文本中的数据,不会出现中文乱码。