当前位置: 首页 > news >正文

Java 环境变量中 bin 与 lib 的由来

下面有两个java环境变量脚本

export JAVA_HOME=/usr/local/java export JRE_HOME=${JAVA_HOME}/jre export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib export PATH=${JAVA_HOME}/bin:$PATH
# Zulu JDK 8 Environment Variables export JAVA_HOME=/usr/local/java export JRE_HOME=$JAVA_HOME/jre export PATH=$JAVA_HOME/bin:$PATH export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar

一、为什么 PATH 用bin,CLASSPATH 用lib

很多初学者第一次看到环境变量配置时都会问:
“为什么一会儿写bin,一会儿写lib,到底该指向哪里?”

其实这两个目录职责完全不同,不是“随便挑一个”,而是各司其职

变量用途必须目录目录内容
PATH让 Shell 找到可执行文件$JAVA_HOME/binjavajavacjps等命令
CLASSPATH让 JVM 找到类库/包$JAVA_HOME/lib$JRE_HOME/libtools.jardt.jarrt.jar

因此,

  • 想在命令行里直接敲java→ 把bin塞进PATH

  • 想让程序编译或运行期找到 JDK 自带工具类 → 把lib下的 jar 放进CLASSPATH

二、两种 CLASSPATH 写法对比

在 JDK 8 时代,网上流传两种典型配置:

  1. 目录级兜底型

    CLASSPATH=.:$JAVA_HOME/jre/lib:$JAVA_HOME/lib
    • 把整个lib目录扔给类加载器,不会漏掉任何官方 jar

    • 优点:简单粗暴,换机器也不易翻车。

    • 缺点:会额外扫描目录,若里面有“野 jar”可能被意外加载。

  2. 精确 jar 可控型

    CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
    • 只显式声明工具类tools.jar)和Swing 配套dt.jar)。

    • 优点:依赖锁定,脚本可移植,干净清爽。

    • 缺点:
      – 若代码里偷偷用了sun.*com.sun.*而其他 jar 没写全,就ClassNotFound
      – 遇到 OpenJDK 裁剪版或自定义 JRE(Alpine、jlink)时,rt.jar 被拆散,这种写法会失效。

Oracle 官方文档给出的范例其实是折中方案:

CLASSPATH=.:$JAVA_HOME/lib/tools.jar:$JAVA_HOME/jre/lib/rt.jar

——既精确,又包含核心运行时。

三、实战怎么选

场景推荐
本地开发、学习,图省事目录级写法,直接.:$JAVA_HOME/jre/lib:$JAVA_HOME/lib
写启动脚本、做发布包,追求可重复、可移植显式列出 jar,并随 JDK 版本一起测试
Java 9 及以后别再手动拼 CLASSPATH!用模块路径(--module-path)即可

四、一句话总结

bin给操作系统找命令,lib给 JVM 找类;
CLASSPATH 的“目录级”兜底最全,“精确 jar”干净可控——
在 JDK 8 下两种都对,选谁取决于你对“省事”还是“可控”的偏好。

⚠️ 注意:

  • Java 9 开始tools.jardt.jar被移除了,不再需要手动加进 CLASSPATH

  • 如果你用的是 Java 11+,CLASSPATH 通常可以留空或只保留.




http://www.rkmt.cn/news/181488.html

相关文章:

  • CentOS-Stream-10 搭建FTP服务器之虚拟用户访问(一)
  • 日语二类动词如何变化
  • JupyterLab远程开发配置:Miniconda-Python3.9镜像实操记录
  • HTML可视化调试利器:Miniconda-Python3.9集成Plotly开发实战
  • Anaconda配置PyTorch环境变量的正确姿势
  • Anaconda配置PyTorch时出现UnsatisfiableError怎么办?
  • ASP.NET Core 中 IHostedService 构造函数未被调用的排查与解决
  • Miniconda-Python3.9镜像如何提升你的AI开发效率?
  • 清华源加速pip安装!Miniconda-Python3.9镜像配置国内源教程
  • Conda create虚拟环境命名规范与最佳实践
  • Markdown文档编写+代码执行:Miniconda-Jupyter一体化工作流
  • 2025 MBA必备!10个AI论文软件测评:开题报告写作全攻略
  • 成人无人机技能培训服务哪家可靠?口碑好的成人无人机技能培训哪家强? - 工业设备
  • 2026年厂房管道安装工程承包商推荐:五家专业公司综合对比与选择指南 - 品牌2025
  • 一般通过什么软件收集、分析和可视化数据?
  • 国产镀层测厚仪靠谱生产厂家,常见品牌有哪些推荐? - 品牌推荐大师
  • 融合CBMA注意力机制的TCN-SVM故障诊断模型,江南大学、西储大学轴承数据为例---MATLAB代码
  • 厂房恒温恒湿工程设计施工一体化承包推荐:2026年优质选择指南 - 品牌2025
  • 2026年精密制造厂房恒温恒湿工程,专业团队如何选择? - 品牌2025
  • 吃透Java反射(面试必看)
  • HTML动态图表展示:Miniconda环境下使用Bokeh实战
  • 漏洞挖掘指南:小白进阶实战「数字侦探」,月入 3 万核心技能全解析
  • 元旦福利变现指南,永辉超市购物卡高效回收攻略 - 京顺回收
  • X1500型双轴撕碎机结构设计
  • 实用程序:Python打造进程网络监控与分析工具——全方位掌握你的网络与进程状态
  • 2025年成都靠谱西餐培训学校排行榜,新测评精选学做西餐培训学校推荐 - myqiye
  • 多工作台石材切机设计
  • SRC视角下:渗透测试中的逻辑漏洞思路一览,黑客技术零基础入门到精通实战教程!
  • 2025锡膏柜哪家好?锡膏机推荐及解析 - 栗子测评
  • Postman设置接口关联,实现参数化