对于 Java 开发工程师来说,Maven 是依赖管理和代码构建的标准。遵循「约定大于配置」理念。Maven 是 Java 开发工程师日常使用的工具,本篇文章简要介绍一下 Maven 的依赖树解析。

依赖树结构

在 pom.xml 的 dependencies 中声明依赖包后,Maven 将直接引入依赖,并通过解析直接依赖的 pom.xml 将传递性依赖导入到当前项目,最终形成一个树状的依赖结构。

原则:深度优先遍历依赖,并缓存节点剪枝。比如下图:

  • A→B→D→E/F
  • A→C→D

在第二步A→C→D时,由于节点D已经被缓存,所以会立即返回,不必再次遍历E/F,避免重复搜索。

依赖冲突

但是假如 2 个包同时依赖了同一个 jar 包,但是这个 jar 包版本不同,规则是什么样的呢?比如下图 A 通过 B 和 D 引入了 1.0 版本的 E,同时 A 通过 C 引入了 2.0 版本的 E。针对这种多个版本构建依赖时,Maven 采用「短路径优先」原则,即 A 会依赖 2.0 版本的 E。如果想引入 1.0 版本的 E,需要直接在 A 的 pom 中声明 E 的版本。

如果 Java 项目过于庞大,或者依赖传递过于复杂时,可以使用 dependencyManagement 定义默认的版本号,一次定义全局生效,避免开发者自行管理依赖的版本。

依赖循环

比如:A 依赖了 B,同时 B 又依赖了 A。这种循环依赖可能不会直接显现,但是可能会在一个很长的调用关系显现出来,也可能是模块架构的设计不合理。

我们可以使用 mvn dependency:tree -Dverbose | grep cycle 来判断项目中是否存在「循环依赖」。

依赖排除

我们可以使用 exclusion 来解决依赖冲突,但是 exclusion 会降低 Maven 依赖解析的效率,因为对应的 pom 文件不能缓存,每次都要重新遍历子树。

对于依赖排除:

  • exclusion 会造成依赖重复扫描和缓存。
  • 在距离根节点越远的 exclusion,影响的范围越小。
  • 依赖树高度越高,引入 exclusion 的代价越大。

依赖分析

IDEA 插件

使用 IDEA 的话,可以在对应项目中右击,选择 Diagrams -> Show Dependencies。

Maven 命令行

mvn dependency:tree -Dverbose

公众号

coding 笔记、点滴记录,以后的文章也会同步到公众号(Coding Insight)中,希望大家关注_

代码和思维导图在 GitHub 项目中,欢迎大家 star!

最新文章

  1. Java简易日历的实现
  2. SQL 查询总结
  3. 十三、Java基础---------多线程总结
  4. python之网络爬虫
  5. 高效查看MySQL帮助文档的方法
  6. HDU 5371 Hotaru's problem (Manacher,回文串)
  7. iOS 开发调试技巧
  8. 【学习总结】 init & initWithFrame & initWithCoder
  9. I have a dream
  10. layer 关闭当前弹出层
  11. websocket采用tomcat方式,IOC类对象无法注入的解决方案
  12. Codeforces round 1098
  13. Sequence(priority_queue)
  14. .net core 读取本地指定目录下的文件
  15. 前端实现文件在线预览txt,pdf,doc,xls,ppt几种格式
  16. ElasticSearch(二):windows下ElasticSearch6.3.2插件Head的安装
  17. 【[HNOI2005]狡猾的商人】
  18. sql 循环表中记录
  19. App测试从入门到精通之安装、卸载和运行测试
  20. Unity3D研究院之手游开发中所有特殊的文件夹

热门文章

  1. Centos7中MySQL8.0安装过程及遇到的问题记录
  2. python爬虫使用scrapy框架
  3. python类变量与成员变量
  4. [Luogu P2278] [HNOI2003]操作系统
  5. 【Luogu】P1072 Hankson 的趣味题 题解
  6. 6.1 接口 - 6.3 lambda表达式
  7. 2020 校招,我是如何拿到小米、京东、字节大厂前端offer
  8. 论文解读 - MaskGAN:BETTER TEXT GENERATION VIA FILLING IN THE _____
  9. jquery自定义弹层显示大图(兼容多层iframe)
  10. RPA小结