JDK和JRE怎么选?Java环境区别详解
时间:2026-02-22 17:17:48 159浏览 收藏
JDK与JRE的选择早已不是非此即彼的纠结——从Java 11起,Oracle已停止提供独立JRE安装包,主流OpenJDK发行版也默认不再打包JRE;事实上,现代Java开发只需安装JDK即可,它已完整包含运行和编译所需的一切,而传统JRE已被Java 9+的jlink工具取代,支持按需定制最小化、安全、轻量的运行时镜像;真正关键的不是“装哪个”,而是正确配置JAVA_HOME指向JDK根目录、理解PATH与java命令的实际调用逻辑,以及避免因模块缺失(如遗漏java.desktop)或环境误配导致的常见陷阱——掌握这些,才能告别过时概念,高效、可靠地驾驭Java生态。

开发用 JDK,运行用 JRE —— 但绝大多数情况下,你只需要装 JDK 就够了,JRE 已经被 JDK 包含,且从 Java 11 起 Oracle 官方不再单独提供 Windows/macOS 的 JRE 下载。
为什么现在基本不用单独装 JRE
Java 11 是分水岭:Oracle 停止为桌面端发布独立 JRE 安装包;OpenJDK 社区版本(如 Temurin、Zulu)也默认不提供 JRE 构建。所谓“JRE”,实际是 JDK 中的 jre 子目录(Java 8 及以前)或更轻量的 jlink 自定义运行时(Java 9+)。
- Java 8:JDK 安装后自带
JAVA_HOME/jre/目录,可直接当 JRE 用 - Java 9+:JDK 不再附带
jre文件夹,但可通过jlink工具按需生成最小化运行时,例如:jlink --module-path $JAVA_HOME/jmods --add-modules java.base,java.desktop --output myjre
- 部署场景中若真需要精简运行环境,应优先用
jlink生成定制镜像,而不是找“JRE 安装包”——后者早已过时或不可信
JDK 和 JRE 在 PATH 和 JAVA_HOME 上怎么配
JAVA_HOME 必须指向 JDK 根目录(如 C:\Program Files\Java\jdk-17.0.2),不能指向其下的 jre 子目录(Java 8 兼容写法)或任意 runtime 目录;否则 javac 会报错“command not found”或 tools.jar 找不到。
PATH中应包含$JAVA_HOME/bin,这样java、javac、jlink等命令才可用- 不要把
JAVA_HOME设成C:\...\jdk-17.0.2\jre—— 这在 Java 9+ 根本不存在,在 Java 8 下会导致javac失效 - 验证方式:
echo $JAVA_HOME # Linux/macOS<br>java -version<br>javac -version
两个 version 输出一致且不报错,说明配置正确
运行 Java 程序时,到底用的是哪个“Java”
真正决定运行行为的是启动命令调用的 java 可执行文件路径,而非 JAVA_HOME —— 后者只是开发工具链(如 Maven、IDEA)用来定位 javac 或 tools.jar 的辅助变量。
- 如果你双击
xxx.jar运行,系统用注册表(Windows)或/usr/bin/java(Linux)或/usr/libexec/java_home(macOS)找默认java,和JAVA_HOME无关 - 如果你执行
java -jar app.jar,Shell 查PATH找第一个java,可能来自 JDK、JRE、或 SDKMAN 安装的某个版本 - IDE(如 IntelliJ)默认用项目配置的 JDK,但运行配置里可单独指定
JRE—— 这里的 “JRE” 实际是 JDK 的一个引用别名,不是独立安装包
真正容易出问题的地方在于:误以为“装了 JRE 就能编译”,结果 javac 找不到;或者在 CI/CD 中用 jlink 生成的运行时没包含 java.desktop 模块,却去跑 Swing 程序——这些都不是“选 JDK 还是 JRE”的问题,而是对模块化和运行时构成的理解偏差。
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《JDK和JRE怎么选?Java环境区别详解》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
398 收藏
-
106 收藏
-
390 收藏
-
357 收藏
-
320 收藏
-
103 收藏
-
205 收藏
-
344 收藏
-
495 收藏
-
147 收藏
-
305 收藏
-
465 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习