Maven Jar 加载原则优先级梳理

在 Maven 项目中,加载 JAR 包的优先级和顺序是一个重要的概念。理解这些原则有助于解决依赖冲突和确保项目的正确构建。以下是 Maven 加载 JAR 包的优先级原则:

  1. 直接依赖(Direct Dependencies):

    • 首先,Maven 会加载直接声明在 pom.xml 文件中的依赖项。这些依赖项通常位于 <dependencies> 标签内。
  2. 传递依赖(Transitive Dependencies):

    • 对于每个直接依赖,Maven 还会加载其传递依赖。传递依赖是指一个库所依赖的其他库。例如,如果 A 依赖于 B,而 B 又依赖于 C,那么 C 就是 A 的传递依赖。
  3. 依赖范围(Dependency Scopes):

    • Maven 会根据依赖的范围来决定是否加载某个依赖。常见的依赖范围包括:
      • compile: 默认范围,适用于所有阶段(编译、测试、运行)。
      • provided: 只在编译和测试时可用,运行时由容器提供。
      • runtime: 只在运行和测试时可用,编译时不可用。
      • test: 只在测试时可用,编译和运行时不可用。
      • system: 类似于 provided,但需要显式指定路径。
  4. 版本管理(Version Management):

    • 如果多个依赖项引用了同一个库的不同版本,Maven 将根据以下规则选择版本:
      • 最短路径优先: Maven 会选择距离根节点最近的依赖版本。
      • 第一声明优先: 如果两个依赖项具有相同的路径长度,Maven 会选择第一个声明的版本。
  5. 排除依赖(Exclusions):

    • 可以通过 <exclusions> 标签来排除某些传递依赖。例如:

      <dependency> <groupId>com.example</groupId> <artifactId>example-dependency</artifactId> <version>1.0.0</version> <exclusions> <exclusion> <groupId>org.unwanted</groupId> <artifactId>unwanted-library</artifactId> </exclusion> </exclusions> </dependency>

  6. 插件依赖(Plugin Dependencies):

    • Maven 插件本身也有自己的依赖,这些依赖会在插件执行时被加载。
  7. 父 POM 和继承(Parent POM and Inheritance):

    • 如果项目继承了父 POM,父 POM 中的依赖也会被加载。子模块可以覆盖或添加新的依赖。
  8. 仓库(Repositories):

    • Maven 会从本地仓库、远程仓库以及中央仓库中查找并下载所需的依赖。
  9. Profiles(配置文件):

    • 通过激活不同的 Maven 配置文件,可以改变依赖的加载方式。例如,开发环境和生产环境可以使用不同的依赖配置。
相关推荐
tHeya06II15 分钟前
涵盖 Cursor、Claude Code、Skills
java·服务器
kim_puppy17 分钟前
TCP的三次握手,四次挥手
java·网络·tcp
诗人不写诗17 分钟前
spring boot apm生态
java·数据库·spring boot
海参崴-18 分钟前
C++代码格式规范
java·前端·c++
better_liang42 分钟前
每日Java面试场景题知识点之-Redisson热门使用场景
java·redis·微服务·分布式锁·redisson·分布式系统
2301_792674861 小时前
java学习 day26
java
so2F32hj21 小时前
拆解 OpenHands(14)--- Microagents
java·开发语言
明灯伴古佛1 小时前
面试:什么是可重入性?为什么 synchronized 是可重入锁?
java·jvm·面试
卓怡学长1 小时前
m307自习室预订座位管理分析与实现
java·spring boot·spring
Arya_aa1 小时前
生猪养殖溯源系统前期准备与SpringBoot框架
java·spring boot