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 配置文件,可以改变依赖的加载方式。例如,开发环境和生产环境可以使用不同的依赖配置。
相关推荐
又是忙碌的一天18 小时前
Java IO流
java·开发语言
程序员buddha18 小时前
springboot-mvc项目示例代码
java·spring boot·mvc
不懂英语的程序猿18 小时前
【Java 工具类】Java通过 TCP/IP 调用斑马打印机(完整实现)
java
多多*20 小时前
分布式系统中的CAP理论和BASE理论
java·数据结构·算法·log4j·maven
sg_knight20 小时前
Docker 实战:如何限制容器的内存使用大小
java·spring boot·spring·spring cloud·docker·容器·eureka
合作小小程序员小小店20 小时前
web网页开发,在线考勤管理系统,基于Idea,html,css,vue,java,springboot,mysql
java·前端·vue.js·后端·intellij-idea·springboot
随便叫个啥呢1 天前
java使用poi-tl模版+vform自定义表单生成word,使用LibreOffice导出为pdf
java·pdf·word
面向星辰1 天前
扣子开始节点和结束节点
java·服务器·前端
烤麻辣烫1 天前
黑马程序员苍穹外卖(新手)Day1
java·数据库·spring boot·学习·mybatis
失散131 天前
分布式专题——51 ES 深度分页问题及其解决方案详解
java·分布式·elasticsearch·架构