关于Java奇数最后一个字符输出乱码问题
yqxbc 发布时间:04-05 来源:一起学编程 浏览:53次

首先引入网络上的一段文字:

BufferedReader reader = newBufferedReader(new InputStreamReader(System.in));

String message;

while((message= reader.readLine()) != null){

System.out.println(message);

}

这是很常见的获取键盘输入的一段Java代码,但在运行过程中,我发现只要我输入的是中文,而且字符数为奇数,就会出现最后一个字符为乱码的问题,花了一下午的时间找问题,查原因,最后一篇文章帮我找到了原因:

产生原因:因为这个开源项目的默认字符编码为UTF-8,所以我的控制台的字符编码也自动变成了UTF-8,而键盘的输入流的默认格式是GBK格式,这样就造成了在GBK转UTF-8的过程中产生的奇数乱码错误(这个问题的解释可以在搜索引擎找到)。

解决办法:

  1.在代码区域右键 -> run as -> run configurations -> common(右侧) -> console encoding

  如果出现此错误,此时的编码格式应该是UTF-8,选择Other,这时可能没有GBK选项,如果没有,则执行之后操作。

  2.更改该项目的文本文件编码,项目右键 -> properties -> resource -> 先将 text file encoding调整回GBK,然后再回去重新设置console encoding编码为GBK。

  现在很多项目要求在项目开始之前统一字符编码为UTF-8,这是为了更好的支持国际化,这无可避免得可能会出现控制台乱码这类比较偏门的问题(最少我查了挺久的),所以写出来给大家分享一下~

  根据我的试验,更改文件编码由GBK->UTF-8,不需要修改控制台编码,因为控制台对于该文件的运行设置将自动变为utf-8编码,之后的输出到别的地方的文本也不会乱码了,也就是说代码文件、输入、输出所有地方的编码统一,就不会出现乱码问题了~~

如果你有好的win10资讯或者win10教程,以及win10相关的问题想要获得win10系统下载的关注与报道。
欢迎加入发送邮件到657025171#qq.com(#替换为@)。期待你的好消息!