解决Javac 编译时报"编码GBK的不可映射字符

在java代码中出现汉字时,编译会报错

public class helloworld {
    public static void main(String[] args) {
        System.out.println("你好哇");
    }
}

通过DOS编译 提示 错误:编码GBK的不可映射字符

检查

1、 查本机区域语言设置中文没有问题
2、 此程序可以在eclipse上正常运行
右键properties-resource-text file encoding 查是UTF-8

解决办法

1、运行是使用javac -encoding UTF-8 helloworld.java
编译通过

2、记事本打开java源文件,另存为选择ANSI编码

说明

ANSI:美国国家标准协会,系统预设的标准文字储存格式。简体中文编码GB2312,实际上它是ANSI的一个代码页936

UTF-8:通用字集转换格式,这是为传输而设计的编码,2进制,以8位为单元对Unicode进行编码,如果使用只能在同类位元组内支持8个位元的重要资料一类的旧式传输媒体,可选择UTF-8格式。

在UTF-8里,英文字符仍然跟ASCII编码一样,因此原先的函数库可以继续使用。而中文的编码范围是在0080-07FF之间,因此是2个字节表示(但这两个字节和GB编码的两个字节是不同的),用专门的Unicode处理类可以对UTF编码进行处理。


转载请注明出处@Berome

打赏
  • 版权声明: 本博客所有文章除特别声明外,均采用 Apache License 2.0 许可协议。转载请注明出处!
  • © 2015-2020 Berome
  • Powered by Hexo Theme Ayer
  • PV: UV:

请我喝杯咖啡吧~

支付宝
微信