`
HolyLin
  • 浏览: 29116 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
最近访客 更多访客>>
社区版块
存档分类
最新评论

Eclipse编译过程的困惑

    博客分类:
  • Java
阅读更多
在Eclipse把编码方式设为UTF-8,写如下程序:

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处理方式的不同?有哪位达人出来指点迷津下?
分享到:
评论
2 楼 plato 2006-11-11  
Eclipse是用的JDT来编译, JDT依赖于Eclipse IFile对象, 所以JDT可以通过IFile的方法获取IFile的Encoding.

另外我在command下试过了javac -encoding UTF-8, 可以通过
1 楼 ddandyy 2006-11-11  
编译不过报的什么

相关推荐

Global site tag (gtag.js) - Google Analytics