Windows上JAVA_HOME路径大小写不敏感,但Linux/macOS严格区分;JAVA_HOME变量名必须全大写,否则被忽略;需用javac -version、mvn -v等多命令交叉验证实际生效路径。

Windows 上 JAVA_HOME 和 Path 中的路径大小写不敏感
Windows 文件系统默认不区分大小写,所以 JAVA_HOME 设为 C:\Program Files\Java\jdk-17.0.1 或 c:\program files\java\jdk-17.0.1 效果完全一样。但要注意:Path 环境变量里引用 %JAVA_HOME%\bin 时,如果 JAVA_HOME 值本身含非法空格或特殊字符而未加引号,启动某些工具(如 Maven、Gradle)可能报 The filename, directory name, or volume label syntax is incorrect 错误。
-
JAVA_HOME值建议用英文路径,避免中文或空格;若必须含空格,无需在环境变量中加引号(Windows 不支持),应改用 8.3 短名(如C:\Progra~1\Java\...)或迁移 JDK 到无空格路径 - 检查
Path是否重复添加了java.exe的多个路径,容易导致java -version和javac -version显示不同版本 - 修改后必须重启命令行终端(CMD/PowerShell)或 IDE,否则新变量不可见
Linux/macOS 中 JAVA_HOME 路径大小写严格敏感
Unix-like 系统文件路径区分大小写,/usr/lib/jvm/java-17-openjdk-amd64 和 /usr/lib/jvm/java-17-openjdk-AMD64 是两个完全不同路径。设错会导致 java 命令正常但 javac 找不到,或构建时报 Exception in thread "main" java.lang.NoClassDefFoundError: javax/tools/JavaCompiler。
- 用
readlink -f $(which java)反推真实 JDK 安装路径,再据此设置JAVA_HOME - 在
~/.bashrc或/etc/profile中导出时,务必确保路径拼写与ls -ld输出一致(注意大小写、连字符、下划线) - OpenJDK 包名常含
openjdk小写,而某些厂商 JDK(如 Zulu)路径含Zulu大写,不能凭记忆硬写
JAVA_HOME 变量名本身在所有系统中都必须全大写
Java 启动脚本(如 java、javac、mvn)内部硬编码检查的是 JAVA_HOME 这个全大写名称。设成 java_home、Java_Home 或 JAVA_HOME_PATH 都会被忽略,退而使用系统默认查找逻辑(可能找到 JRE 而非 JDK,导致 javac 不可用)。
- Windows 下可通过
set JAVA_HOME快速确认是否生效;Linux/macOS 用echo $JAVA_HOME - IDE(如 IntelliJ IDEA)的 Project SDK 设置优先级高于系统
JAVA_HOME,但 Maven/Gradle 控制台运行仍依赖该变量,二者不一致时容易出现“IDE 里能编译,终端里编译失败” - 某些 Docker 基础镜像(如
eclipse-jdk17)已预设JAVA_HOME,自定义镜像中覆盖时需确认是否被 ENTRYPOINT 脚本重置
验证是否真正生效:别只信 java -version
java -version 成功只说明运行时环境就绪,不反映编译器或构建工具是否用了你设的 JDK。真正要查的是 javac -version、mvn -v 输出里的 Java home 路径,以及 Maven 编译时日志中实际加载的 tools.jar(JDK 9+ 已移除,但会显示 jdk.compiler 模块来源)。
立即学习“Java免费学习笔记(深入)”;
- 执行
java -XshowSettings:properties -version 2>&1 | grep java.home
可看到 JVM 实际读取的 home 路径(注意不是JAVA_HOME,而是运行时解析后的值) - Maven 默认用
JAVA_HOME,但可被MAVEN_OPTS或pom.xml中maven-compiler-plugin的source/target覆盖——这属于语义版本控制,和环境变量无关 - Spring Boot CLI、jshell、jdeps 等工具也依赖
JAVA_HOME,设错时可能静默回退到系统 PATH 中第一个java,行为难以察觉
JAVA_HOME 导出,最后用多条命令交叉验证,而不是只跑一遍 java -version 就认为搞定了。










