Maven依赖冲突你会怎么解决

直奔主题,课外知识自行脑补。

1、传递依赖和继承依赖

继承依赖是个啥?就是你定义了一个父模块,然后子模块的pom里定义了parent去引用父模块,然后子模块会继承父模块的声明。

再简单多说一句多模块和继承的在编译时的玩法:

1、有依赖关系的多模块项目,工程结构如下图

1)直接编译父项目。maven会通过Reactor机制制定编译顺序(maven会找到各子module的关系),maven知道父模块下的所有子模块,并会按照依赖关系依次处理执行依次编译所有项目。

2)编译maven子项目时,maven不仅对子项目编译执行,也编译执行了父项目,但不会编译兄弟项目及其兄弟项目的子项目。

2、不具有依赖关系的多模块项目

即兄弟项目间互不关联,都只与父项目存在依赖关系。表现就是对于这类型的项目,我们可以删除父模块的...</modules>部分,而子模块保留parent部分。此时项目不再是一个多模块项目,而是多工程项目的一个集合。

1)此时编译父模块就只会编译父模块自己。

2)编译子模块时,会将子模块和父模块一块编译,但不会编译兄弟模块。

3)若保留父模块的<modules>...</modules>部分而删除子模块的parent部分,那么项目不再是父子项目,只是一个多模块项目,每个子项目独享自己的资源,不能共享。

跑题了,接着讲:

一、继承依赖,

只需记住这句:子模块会依赖父模块的声明,若子模块单独声明,就用自己的。

二、传递依赖

假如A依赖B,B依赖C,那么A也依赖C。(也有例外啊,如果B依赖C时指定了optional为true,标记为可选依赖,则A不会依赖C)。

传递性依赖有以下几个规则:

1)         最短路径原则:如果A对于依赖路径中有两个相同的jar包,那么选择路径短的那个包,路径最近者优先,上述会选X(2.0)。

2)         第一声明优先原则:如果A对于依赖路径中有两个相同的jar包,路径长度也相同,那么依赖写在前面的优先。例如:A->B->F(1.0),A->C->F(2.0),会选F(1.0)。

3)         可选依赖不会被传递,如A->B,B->C,B->D,A对B直接依赖,B对C和D是可选依赖,那么在A中不会引入C和D。可选依赖通过optional元素配置,true表示可选。如果要在A项目中使用C或者D则需要显式地声明C或者D依赖。

讲到这里说说今天要说的重点,也是写这篇文章的缘由,Maven dependencyManagement中的依赖版本会覆盖传递依赖版本。

现在有如下工程:maven_dep_demo 是父module,有dao,service,web三个子module,子module的依赖关系dao->service->web.


回答完下面几道题,maven的一些基础依赖,你基本就理解的差不多了,一定要自己下去多试,答题时间开始:

第一题:

1)dao引用了spring-core的5.1.6.

2)service只是引用的dao

3)web 在dependencyManagement中定义了spring-core 的版本是4.3.23

那大家猜一下,在dao,service 和web中显示的spring的版本号是什么?

答案是:

结论:pom文件中没有指定版本的依赖或是传递的依赖,如果在本module中dependencyManagement中有指定此依赖版本,那就使用本module中dependencyManagement中定义的版本号。

第二题:

1)dao引用了spring-core的5.1.6.如上

2)service只是引用的dao,如上

3)web 只是引用了service。

4)父pom中在dependencyManagement中定义了spring-core 的版本是4.3.23.RELEASE


那大家猜一下,在dao,service 和web中显示的spring的版本号是什么? 

结论:如果在dependency中没有指定version,那么就会依次找当前pom中以及父pom中的dependencyManagement是否定义了版本。

第三题:

1)dao引用了spring-core的5.1.6.如上

2)service只是引用的dao,如上

3)web 在dependencyManagement中定义了spring-core 的版本是4.3.23

4)父pom中在dependencyManagement中定义了spring-core 的版本是3.2.9


那大家猜一下,在dao,service 和web中显示的spring的版本号是什么? 

结论:子的永远优先父的。

第四题:

1)我给原来的工程里添加一个module叫common,common继承父pom。common中引用spring3


2)dao引用了spring-core的5.1.6.

3)service只是引用的dao

4)在web里定义dependencyManagement引用common,且web引用service。

那大家猜一下,在dao,service 和web中显示的spring的版本号是什么? 

第五题:

1)我给原来的工程里添加一个module叫common,common继承父pom。common中引用spring3


2)dao引用了spring-core的5.1.6.

3)service只是引用的dao

4)在web引用service。。

5)在父pom里定义dependencyManagement引用common

那大家猜一下,在dao,service 和web中显示的spring的版本号是什么? 

结论:dependencyManagement的定义不具有传递性。

第六题:

1)我给原来的工程里添加一个module叫common,common继承父pom。


common中只是dependencyManagementspring3.2.9

2)dao引用了spring-core的5.1.6.

3)service只是引用的dao

4)在web引用service。。

5)在父pom里空的。

6)web的引用common

那大家猜一下,在dao,service 和web中显示的spring的版本号是什么? 

第七题:

1)我给原来的工程里添加一个module叫common,common继承父pom。


common中dependencyManagement spring3.2.9且依赖。

2)dao引用了spring-core的5.1.6.

3)service只是引用的dao

4)在web引用service。。

5)在父pom里空的。

6)web的引用common

那大家猜一下,在dao,service 和web中显示的spring的版本号是什么? 

dao 和 service 变成了spring5,web中变成了这样


第八题:

1)我给原来的工程里添加一个module叫common,common继承父pom。如上

common中只是dependencyManagement 

2)dao引用了spring-core的5.1.6.

3)service只是引用的dao

4)在web引用service。。

5)在父pom里空的。

6)web的引用common,但是type是pom,scope是import


那大家猜一下,在dao,service 和web中显示的spring的版本号是什么? 

dao 和 service 变成了spring5,web中变成了这样


第九题:

1)我给原来的工程里添加一个module叫common,common继承父pom。如上

common中只是dependencyManagement 

2)dao引用了spring-core的5.1.6.

3)service只是引用的dao

4)在web引用service。。

5)在父pom里dependencyManagement common,但是type是pom,scope是import。

6)web的引用common

那大家猜一下,在dao,service 和web中显示的spring的版本号是什么? 

dao是spring 5, service 和web 变成了spring3,web中变成了这样

结论:import就是把pom的配置导进来。跟你写在里面差不多。

综上所述:

1、pom文件中没有指定版本的依赖或是传递的依赖,如果在本module中dependencyManagement中有指定此依赖版本,那就使用本module中dependencyManagement中定义的版本号。

2、如果在dependency中没有指定version,那么就会依次找当前pom中以及父pom中的dependencyManagement是否定义了版本。

3、子的永远优先父的。

4、dependencyManagement的定义不具有传递性。

5、import就是把pom的配置导进来

6、工具不好用就,就用命令吧maven -X dependency:tree

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342