Java依赖管理需通过Maven或Gradle声明,而非全局安装;Maven在pom.xml中配置dependency并指定scope,Gradle用implementation/api等关键字控制传递性;手动添加JAR易导致依赖缺失或冲突,应避免。
Java本身不提供类似 pip install 或 npm install 那样的全局库安装机制。所谓“安装第三方库”,实际是让构建工具(如 Maven 或 Gradle)在编译/运行时把对应 JAR 包拉进项目 classpath。你不能像 Python 那样在系统级“装一个 commons-lang”,而必须在每个项目里声明它需要什么版本的 org.apache.commons:commons-lang3。
Maven 是最主流的 Java 依赖管理工具。它不下载到全局目录,而是默认存到本地 ~/.m2/repository,多个项目共享同一份缓存,但各自独立解析依赖树。
添加一个库只需三步:
片段pom.xml 的 块中例如引入 Lombok:
org.projectlombok lombok1.18.34 provided
注意 scope:provided 表示只在编译期需要、运行时不打包;runtime 表示编译不用但运行要;默认是 compile(编译+运行都需)。选错会导致 NoClassDefFoundError 或 IDE 报红但运行正常等反直觉问题。
Gradle 更灵活,但初学者容易混淆 implementation 和 api。它们都影响依赖传递性:
implementation 'com.google.guav
a:guava:33.2.1-jre':当前模块用,下游模块看不到这个依赖api 'org.slf4j:slf4j-api:2.0.13':当前模块用,且下游模块也能直接用它(适合公共 API 层)如果只是写个普通应用,95% 场景用 implementation 就行。误用 api 会导致依赖泄露,下游莫名其妙多出一堆 transitive 依赖,构建变慢、冲突概率上升。
Gradle 还支持 runtimeOnly、testImplementation 等更细粒度的 scope,和 Maven 的 一一对应,但语法更简洁。
有人会把下载好的 xxx.jar 放进 lib/ 目录,再在 IDE 里右键 “Add as Library”。这种做法看似简单,实则埋雷:
okhttp-4.12.0.jar,但它依赖 okio-3.4.0.jar,你得自己找齐)LinkageError
pom.xml 或 build.gradle,别人拉代码根本跑不起来除非调试某个未发布快照版、或公司内网无 Maven *,否则不要手动放 JAR。
真正麻烦的从来不是“怎么加”,而是“加了之后为什么类找不到”“为什么两个库用的同一个类却版本打架”。这些都要靠理解依赖传递、冲突仲裁(Maven 默认取最近定义的版本)、以及善用 mvn dependency:tree 或 ./gradlew dependencies 查真实依赖图。