Oracle文档指出:
-encoding编码 设置源文件编码名,如EUC和UTF-8。如果未指定-encoding,则使用平台默认转换器。
我知道Mac上的平台默认转换器是Mac。但是,当我用UTF-8和许多其他编码编码我的.java文件时,代码编译成功。我还试图迫使javac从Mac编码的程序代码中读取UTF-8和EUC编码,而且它也成功地编译了。
为什么会发生这种情况?我希望以上所有的一切都会失败。
发布于 2016-05-29 08:52:15
编译并运行以下代码:
System.out.println("".length());当文件被保存为UTF-8并解释为UTF-8时,它将打印2,因为笑脸需要存储两个chars。
当文件被解释为MacRoman时,它将打印4,因为UTF-8编码是四个字节长。
(注意:您可以在单元测试中使用此代码以确保正确的编码。)
当你尝试这个:
System.out.println('');编译为MacRoman甚至不起作用。
因此,只要所有的UTF-8内容都是字符串文字和注释,一切似乎都正常。
https://stackoverflow.com/questions/37507885
复制相似问题