最近用idea敲struts,虽然idea的界面很好看,代码提示也很强大,不过也的确是碰到了一些在eclipse上从来没有碰到过的问题,而且我发现,idea的错误,很多都是在外国的网站上提问的人比较多,国内的资料少一点,我竟然慢慢喜欢上了查这些网站的资料。。。。
出现问题
回归正题,出现这个问题的状况是我的电脑本机装的默认jdk版本是1.8.0_71,然后我平常开发用的jdk版本是免安装的1.7,只配置了环境变量,平常用eclipse开发没有出现过这方面的问题,昨天idea也没有出现这个问题,结果今天新建了一个项目,然后设置好了jdk版本,tomcat也设置为了1.7,敲好代码之后已启动,就爆了这个错,如下:
Information:java: Errors occurred while compiling module 'struts2_spring_hibernate_1'
Information:javac 7 was used to compile java sources
Information:Module "struts2_spring_hibernate_1" was fully rebuilt due to project configuration/dependencies changes
Information:2/24/2017 3:28 PM - Compilation completed with 1 error and 0 warnings in 12s 340ms
Error:java: invalid source release: 1.8
解决问题
查了一些资料,有如下解决办法:
1.Settings -> Build, Execution, Deployment -> Compiler -> Java Compiler ,然后设置 project bytecode version为1.7,然后设置如图:
试了,失败。
2.Project Structure ->Modules -> Dependencies ,将Module SDK设置为1.7,如图:
检查了一下,我的设置本来就是1.7,失败
3.最后找到一篇跟我问题差不多的,这个:Error:java: javacTask: source release 8 requires target release 1.8
于是我去检查了一下自己的language level,果然是1.8,将其改为7,运行成功!
课外延伸
那么这个language level为何呢?之前在eclipse里没有见过这个概念,我去查了一下,解释如下:
当我们使用 JDK 8 的时候,我们只能向下兼容 JDK 8 及其以下的特性,所以只能选择 8 及其以下的 language level。所以当我们项目使用的是 JDK 8,但是代码却没有使用 JDK 8 的新特性,最多使用了 JDK 7 的特性的时候我们可以选择 7 - Diamonds,ARM,multi-catch etc.。
对此我们总结 language level:限定项目编译检查时最低要求的 JDK 特性。
现在假设我们有一个项目代码使用的 JDK 8 新特性:lambda 语法,但是 JDK 选择的却是 JDK 7,即使 language level 选择了 8 - Lambdas,type annotation etc.,也是没有多大意义的,一样会编译报错。
所以,language level有点像我们工程最低支持版本。比如Language level 设置了5.0 只是就不能出现使用6.0/7.0特性的代码。