Maven 中的dependencyManagement和dependency的区别

在读项目代码的时候发现,项目中的pom文件里面有两个dependencies,不懂就查一查,学习一下。

首先maven可以通过子模块依赖父模块的方式获得父模块的所有依赖,极大便利的提供了对项目以来的管理,但是在使用这种方式实现对依赖的管理时,子模块不可避免的会引入父模块中存在,但是对自身来说并不需要的依赖,导致引入了冗余的jar包,但使用dependencyManagement 则可以有效避免这个问题。dependencyManagement 具有一下两个特性:

1、在该元素下声明的依赖不会引入到模块中,只有在dependeny中同样声明了该依赖,才会引入到模块中

2、该元素能够约束dependency 下依赖的使用,如果在dependency 中未指定版本,则会使用dependencyManagement 的版本,否则就会覆盖dependencyManagement 指定的版本

 

实现依赖的管理有两种方式:

继承依赖管理

由于 dependencyManagement 元素是可以被继承的,因此我们可以在父模块 POM 中使用 dependencyManagement 元素声明所有子模块的依赖,然后在各个子模块 POM 使用 dependencies 元素声明实际用到的依赖即可。这样既可以让子模块能够继承父模块的依赖配置,还能避免将不必要的依赖引入到子模块中。这种管理方式具有一下优点:

1、模块中使用 dependencyManagement 声明依赖能够统一项目内依赖的版本,子模块无须声明版本,也就不会出现多个子模块使用同一依赖项版本不一致的情况,降低依赖冲突的几率。

2、dependencyManagement 声明的依赖不会被实际引入,子模块需要什么依赖就自己引入,增加了灵活性,避免引入一些不必要的依赖。

导入依赖管理

import 依赖范围只能与 dependencyManagement 元素配合使用才会有效,其功能是将目标 pom.xml 中的 dependencyManagement 配置导入合并到当前 pom.xml 的 dependencyManagement 中。

由于 import 依赖范围的特殊性,一般都是指向打包类型为 pom 的模块,所以 type 元素的值一般为 pom。

若存在多个模块,它们使用的依赖版本都是一致的,则就可以定义一个使用 dependencyManagement 专门管理依赖的 POM,然后在各个模块中导入这些依赖管理配置。

总结一下:dependencyManagement  用于管理依赖,在这个地方声明的dependency没有被dependencies中再次引用,则不会被引入项目中。dependency则增加了就会引入到工程中。

内容来源:http://c.biancheng.net/maven2/dependency-management.html

posted @ 2022-09-14 19:14  charler。  阅读(820)  评论(0编辑  收藏  举报