Java项目指定目标运行版本需协同配置-source、-target和--release参数,推荐使用--release一站式约束语法、API和字节码;Maven通过maven-compiler-plugin设,Gradle用java.toolchain与options.release组合实现精准控制。
在Java项目中指定目标运行版本,关键在于正确配置编译器的源码版本(-source)、字节码目标版本(-target)以及运行时兼容版本(--release或-bootclasspath),三者需协同一致,否则可能引发 UnsupportedClassVersionError 或运行时行为异常。
-source 控制编译器接受的 Java 语法特性(如是否允许 var、switch 表达式);-target 决定生成的 class 文件主版本号(对应 JVM 能否加载);而 --release(推荐使用)则一站式约束语法、API 和字节码版本,自动适配对应 JDK 的系统类库,避免意外调用高版本 API。
--release 11,而非仅设 -source 11 -target 11
--release 自 JDK 9 引入,不支持跨大版本回退(如 JDK 17 不支持 --release 8),此时需搭配对应
JDK 8 编译或使用 -bootclasspath
Maven 默认继承 JDK 版本,但显式声明更可靠。通过 maven-compiler-plugin 统一控制:
org.apache.maven.plugins maven-compiler-plugin3.11.0 11 11
后, 和 会被忽略,且编译过程完全隔离于当前 JDK 的 APIGradle 从 6.7+ 开始推荐使用 java.toolchain + javacArgs 组合实现精准控制:
java {
toolchain {
languageVersion = JavaLanguageVersion.of(11)
}
}
compileJava {
options.release = 11 // JDK 11+ 编译器支持
// 或手动指定:
// options.compilerArgs += ['-source', '11', '-target', '11']
}toolchain 指定构建使用的 JDK,options.release 锁定语义和字节码目标,二者配合最稳妥targetCompatibility,但不如 release 安全编译后可通过 javap -verbose YourClass.class | grep "major version" 查看实际字节码版本(major version 对照表:52→Java 8,55→11,61→17);同时检查运行日志是否出现 java.lang.UnsupportedClassVersionError。
spring-boot-maven-plugin 的 jvmVersion(打包用)是否与编译版本对齐