今天在研究某个开源项目时,有如下代码:
这是很常见的获取键盘输入的一段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,这是为了更好的支持国际化,这无可避免得可能会出现控制台乱码这类比较偏门的问题(最少我查了挺久的),所以写出来给大家分享一下~
- BufferedReader
reader = new BufferedReader(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,这是为了更好的支持国际化,这无可避免得可能会出现控制台乱码这类比较偏门的问题(最少我查了挺久的),所以写出来给大家分享一下~