先运行/usr/libexec/java_home -v确认已注册jvm路径,再检查/library/java/javavirtualmachines、~/library/java/javavirtualmachines、/opt/homebrew/cellar/openjdk等位置,结合which java和java -version验证实际使用版本。

确认当前安装的Java版本和路径
Mac上Java可能通过多种方式安装:系统自带(旧版)、Oracle JDK、OpenJDK(如Adoptium/Temurin)、Homebrew、SDKMAN!,甚至IDE自带的JRE。直接删/Library/Java/JavaVirtualMachines可能漏掉其他位置的残留。
先查清楚你到底装了什么:
- 运行
/usr/libexec/java_home -V—— 显示所有已注册的JVM路径(注意不是所有都对应真实目录) - 检查
/Library/Java/JavaVirtualMachines(系统级JDK) - 检查
~/Library/Java/JavaVirtualMachines(用户级,常见于SDKMAN!或某些IDE安装) - 检查
/opt/homebrew/Cellar/openjdk(Homebrew安装的OpenJDK) - 运行
which java和java -version,再看ls -la $(which java)确认软链指向
删除/Library/Java下的核心目录和配置文件
这个路径是macOS Java生态最易残留的地方,但不能只删JavaVirtualMachines就完事。很多卸载工具或手动删除会忽略配置和缓存。
需要逐个清理以下内容(建议先备份重要配置):
立即学习“Java免费学习笔记(深入)”;
-
/Library/Java/JavaVirtualMachines—— 删除整个文件夹(里面是各JDK的根目录,如jdk-17.jdk) -
/Library/Java/Extensions—— 已废弃但常被遗留,存放全局扩展jar,可直接删 -
/Library/Internet Plug-Ins/JavaAppletPlugin.plugin—— 仅旧版Oracle Java有,现代浏览器已弃用,必须删(否则仍可能在“系统偏好设置→Java”里显示) -
/Library/Preferences/com.oracle.java*和/Library/Preferences/net.java.openjdk*—— plist配置文件,影响Java控制面板状态
清除Shell环境变量和Shell配置中的Java引用
即使JDK文件全删了,终端里java命令仍可能有效,是因为PATH或JAVA_HOME还指向旧路径,或者.zshrc/.bash_profile里硬编码了路径。
检查并清理这些地方:
- 运行
echo $JAVA_HOME和echo $PATH | tr ':' '\n' | grep java - 搜索你的shell配置:
grep -E '(JAVA_HOME|java|jdk)' ~/.zshrc ~/.zprofile ~/.bash_profile ~/.bashrc 2>/dev/null - 删掉类似
export JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk-11.jdk/Contents/Home的行 - 删掉类似
export PATH="/Library/Java/JavaVirtualMachines/.../bin:$PATH"的行 - 改完后执行
source ~/.zshrc(或对应配置文件),再验证java是否报command not found
验证是否还有Java进程、LaunchAgent或残留注册信息
有些Java应用(比如旧版IntelliJ、Eclipse、或企业软件)会在后台注册LaunchAgent,或把自身路径写进/Library/Preferences/com.apple.java.jvm这类系统级plist,导致“Java控制面板”仍显示存在JVM。
手动检查这几个关键点:
- 运行
launchctl list | grep -i java—— 查是否有残留的Java相关服务 - 检查
/Library/LaunchAgents和/Library/LaunchDaemons下带java或oracle的plist文件 - 运行
defaults read /Library/Preferences/com.apple.java.jvm—— 如果报错说明已清空;如果返回内容,用defaults delete /Library/Preferences/com.apple.java.jvm清除 - 重启后打开“系统偏好设置→Java”,如果图标还在,说明
JavaAppletPlugin.plugin没删干净,或某个plist残留触发了UI重建
真正彻底的卸载,难点不在删目录,而在识别哪些路径被哪个安装器注册过、又没提供反向卸载逻辑。尤其SDKMAN!或IDE捆绑的JDK,往往只改PATH不写系统注册表,反而更难追踪。多跑两遍find /Library -name "*java*" -type d 2>/dev/null比依赖记忆靠谱。










