一、问题
今天我在Myeclipse 6.5中,把原来可以正常编译运行的SSH工程,由原来的JDK1.5转换成了JDK1.6,并选择Eclipse的Complier compliance level为6.0,重新启动Tomcat服务,结果控制台出现【java.lang.UnsupportedClassVersionError】错误提示。
二、原因分析
出现 java.lang.UnsupportedClassVersionError 错误的原因,是因为我使用JDK1.6 编译的 Java class 文件试图在JDK1.5版本的 JVM 上运行,所报的错误。
高版本的 JDK 生成的 class 文件使用的格式,可能与低版本的 JDK 的 .class 文件格式不同。这样,低版本的 JVM 无法解释执行这个 .class 文件,会抛出 java.lang.UnsupportedClassVersionError 不支持的 Class 版本错误。
三、解决办法
(1)Window-->Java-->Installed JREs:选择使用JDK1.6
(2)Window-->Java-->Complier-->Complier compliance level:选择5.0或者6.0
(3)Window-->MyEclipse Enterprise Workbench-->Servers-->Tomcat-->Tomcat 6.x-->JDK:修改Tomcat JDK name为1.6
(4)重新部署原来的工程到Tomcat中,服务便可正常启动,问题解决。
四、扩展:Eclipse中Compiler compliance level的含义说明
设置Compiler compliance level为较低版本,只是让编译器相信代码是兼容较低版本的,在编译时生成的 Java class 兼容较低版本。
这样设置与写代码时引用的JDK是没关系的,写代码时可以引用较高版本的JDK,设置Compiler compliance level为较低版本,
这样的好处是当别人使用了较低版本的JDK时也可以引用你写的编译后的代码。
它可以保证编译后的class文件的版本一致性。
但是,如果代码里面调用了较高版本JDK的API,那么即使设置了Compiler compliance level为较低版本,在较低版本的JDK上运行你的代码也会报错。
所以建议在写代码时引用的JDK,要同Compiler compliance level设置的版本一致。