出现此问题的原因:文件的编码,系统的编码,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"));这样转换之后就可以正常读取文本中的数据,不会出现中文乱码。
本文介绍了在使用Java读取文本文件时遇到的中文乱码问题及其解决方案。问题源于文件编码、系统编码与Java默认编码之间的不一致导致。通过使用InputStreamReader类指定正确的编码格式(如GBK),可以有效避免乱码问题。

被折叠的 条评论
为什么被折叠?



