字符流 读取数据 中文乱码

来源:互联网 发布:markov chain python 编辑:程序博客网 时间:2024/05/17 23:28

出现此问题的原因:文件的编码,系统的编码,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"));

这样转换之后就可以正常读取文本中的数据,不会出现中文乱码。



原创粉丝点击