操作背景:我在eclipse建立了个HelloWorld.java文件,格式UTF-8,然后复制保存到C:\Users\alex\test目录下,在此处运行按住Shift+右键调出cmd命令窗口,输入命令:javac HelloWorld.java,
然后报错:HelloWorld.java:6: 错误: 编码GBK的不可映射字符
解决办法:
方法一:带上编码utf-8,运行命令:javac -encoding utf-8 HelloWorld.java,
结果,同目录下出现HelloWorld.class文件,编译成功!
方法二:用记事本另存为ANSI编码格式的,直接运行命令:javac HelloWorld.java
出现对应的class文件,成功!
注意:class类名必须与文件名保持一致!!
如果不一致会报错:b.java:6: 错误: 类a是公共的, 应在名为 a.java 的文件中声明(我把类a的文件名改为b.java后)
例如:上述HelloWorld.java文件里含有的class名必须为HelloWorld,如:public class HelloWorld {}
如果在编译过程中出现报错:错误: 非法字符: \65279...错误: 需要class, interface或enum
就必须先把java文件转为无BOM的utf-8的编码:用notepad++就可以实现转换保存。
这是因为:由于JDK是国际版的,在编译的时候,如果我们没有用-encoding参数指定我们的JAVA源程序的编码格式,则javac.exe首先获得我们操作系统默认采用的编码格式,也即在编译java程序时,若我们不指定源程序文件的编码格式,JDK首先获得操作系统的file.encoding参数(它保存的就是操作系统默认的编码格式,如WIN2k,它的值为GBK),然后JDK就把我们的java源程序从file.encoding编码格式转化为JAVA内部默认的UNICODE格式放入内存中。然后,javac把转换后的unicode格式的文件进行编译成.class类文件,此时.class文件是UNICODE编码的,它暂放在内存中,紧接着,JDK将此以UNICODE编码的编译后的class文件保存到我们的操作系统中形成我们见到的.class文件。对我们来说,我们最终获得的.class文件是内容以UNICODE编码格式保存的类文件,它内部包含我们源程序中的中文字符串,只不过此时它己经由file.encoding格式转化为UNICODE格式了。当我们不加设置就编译时,相当于使用了参数:javac -encoding gbk XX.java,当然就会出现不兼容的情况。
解决办法是:应该使用-encoding参数指明编码方式:javac -encoding UTF-8 XX.java,这下没警告了,运行也正确了在JCreator 4中设置:菜单:Configure --> Options --> JDK Tools --> Compiler,选中<Default>,然后选Edit,Parameters里面,最前面添加:-encoding UTF-8。
Parameters原来的
默认值为:-classpath "$[ClassPath]" -d "$[OutputPath]" $[ModJavaFiles]
修改后为:-encoding UTF-8 -classpath "$[ClassPath]" -d "$[OutputPath]" $[ModJavaFiles]