最近尝试了使用Idea尝试使用Gradle开发多模块项目,结果遇到一个见鬼的问题:
首先,总项目是一个空项目。
第二,我首先建立了两个Java模块,然后建立了一个Spring boot程序模块。
当我建立第四个Java模块的时候发现问题了,系统直接生成的Java程序居然不能运行,报告:
Execution failed for task ':cn.edu.cup.Main.main()'.
> Process 'command 'C:\Users\xpli1\.jdks\graalvm-jdk-17.0.12\bin\java.exe'' finished with non-zero exit value 1* Try:
> Run with --stacktrace option to get the stack trace.
> Run with --info or --debug option to get more log output.
> Run with --scan to get full insights.
> Get more help at https://help.gradle.org.
BUILD FAILED in 310ms
2 actionable tasks: 2 executed
这样的错误。
系统生成的样例代码如下:
package cn.edu.cup;//TIP To <b>Run</b> code, press <shortcut actionId="Run"/> or
// click the <icon src="AllIcons.Actions.Execute"/> icon in the gutter.
public class Main {public static void main(String[] args) {//TIP Press <shortcut actionId="ShowIntentionActions"/> with your caret at the highlighted text// to see how IntelliJ IDEA suggests fixing it.System.out.printf("Hello and welcome!");for (int i = 1; i <= 5; i++) {//TIP Press <shortcut actionId="Debug"/> to start debugging your code. We have set one <icon src="AllIcons.Debugger.Db_set_breakpoint"/> breakpoint// for you, but you can always add more by pressing <shortcut actionId="ToggleLineBreakpoint"/>.System.out.println("i = " + i);}}
}
然后,关闭整个项目,单独打开这一模块的时候,运行正常。
通过对比几个模块gradle.build文件的差异发现,其他模块中都有指定Java版本的 句子,添加了这些语句后,成功运行。
具体的语句为:
java {// 指定源码和目标代码版本sourceCompatibility = JavaVersion.VERSION_17targetCompatibility = JavaVersion.VERSION_17
}
分析原因,估计是新建的项目缺省的java版本与整个项目的版本不一致导致的。