浏览 3613 次
锁定老帖子 主题:Eclipse编译过程的困惑
该帖已经被评为新手帖
|
|
---|---|
作者 | 正文 |
发表时间:2006-11-10
import java.util.Properties; public class Hello { public static void main(String[] args){ String hello = "你好"; Properties properties = System.getProperties(); System.out.println(properties.getProperty("file.encoding")); System.out.println(hello); } } 运行得到如下结果: GBK 你好 但是到DOS窗口下利用命令行 javac Hello.java 却编译不能通过。 用UE打开转到十六进制模式发现确实是UTF-8编码.那么可以这样理解,因为直接用javac编译没有带上encoding参数的话,那么javac就会以系统file.encoding指定的编码来对源程序进行编码,从上面的System.out.println(properties.getProperty("file.encoding"))的输出可以看到默认编码是GBK。这样一来,javac要以GBK来对java文件 进行编码,但是由于Eclipse里却是以UTF-8来保存的,因此出现错误是可以理解的。但是奇怪的是,在Eclipse环境里运行却是没有问题的。难道Eclipse在编译时进行了转换处理?那么它又是如何处理的呢?(本来以为是在javac里带上了encoding参数(javac -encoding utf-8 Hello.java)就可以了,但是发现还是同样的错误),或者是JDT内置的编译器与javac处理方式的不同?有哪位达人出来指点迷津下? 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2006-11-11
编译不过报的什么
|
|
返回顶楼 | |
发表时间:2006-11-11
Eclipse是用的JDT来编译, JDT依赖于Eclipse IFile对象, 所以JDT可以通过IFile的方法获取IFile的Encoding.
另外我在command下试过了javac -encoding UTF-8, 可以通过 |
|
返回顶楼 | |