Maven dependencies與dependencyManagement的區(qū)別詳解
在上一個(gè)項(xiàng)目中遇到一些jar包沖突的問(wèn)題,之后還有很多人分不清楚dependencies與dependencyManagement的區(qū)別,本篇文章將這些區(qū)別總結(jié)下來(lái)。
利用pom管理引用包時(shí),如果是單項(xiàng)目的話就直接在dependencies引用了,若有一個(gè)大工程項(xiàng)目里面包含多個(gè)子模塊,則為了所有項(xiàng)目模塊包的版本統(tǒng)一和好管理,則需要用到dependencyManagement,但兩者使用場(chǎng)景有所區(qū)別。
1、DepencyManagement應(yīng)用場(chǎng)景
當(dāng)我們的項(xiàng)目模塊很多的時(shí)候,我們使用Maven管理項(xiàng)目非常方便,幫助我們管理構(gòu)建、文檔、報(bào)告、依賴、scms、發(fā)布、分發(fā)的方法??梢苑奖愕木幾g代碼、進(jìn)行依賴管理、管理二進(jìn)制庫(kù)等等。
由于我們的模塊很多,所以我們又抽象了一層,抽出一個(gè)itoo-base-parent來(lái)管理子項(xiàng)目的公共的依賴。為了項(xiàng)目的正確運(yùn)行,必須讓所有的子項(xiàng)目使用依賴項(xiàng)的統(tǒng)一版本,必須確保應(yīng)用的各個(gè)項(xiàng)目的依賴項(xiàng)和版本一致,才能保證測(cè)試的和發(fā)布的是相同的結(jié)果。
在我們項(xiàng)目頂層的POM文件中,我們會(huì)看到dependencyManagement元素。通過(guò)它元素來(lái)管理jar包的版本,讓子項(xiàng)目中引用一個(gè)依賴而不用顯示的列出版本號(hào)。Maven會(huì)沿著父子層次向上走,直到找到一個(gè)擁有dependencyManagement元素的項(xiàng)目,然后它就會(huì)使用在這個(gè)dependencyManagement元素中指定的版本號(hào)。
來(lái)看看我們項(xiàng)目中的應(yīng)用:
pom繼承關(guān)系圖:
依賴關(guān)系:
Itoo-base-parent(pom.xml)
<dependencyManagement> <dependencies> <dependency> <groupId>org.eclipse.persistence</groupId> <artifactId>org.eclipse.persistence.jpa</artifactId> <version>${org.eclipse.persistence.jpa.version}</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> <version>${javaee-api.version}</version> </dependency> </dependencies> </dependencyManagement>
Itoo-base(pom.xml)
<!--繼承父類--> <parent> <artifactId>itoo-base-parent</artifactId> <groupId>com.tgb</groupId> <version>0.0.1-SNAPSHOT</version> <relativePath>../itoo-base-parent/pom.xml</relativePath> </parent> <modelVersion>4.0.0</modelVersion> <artifactId>itoo-base</artifactId> <packaging>ejb</packaging> <!--依賴關(guān)系--> <dependencies> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> </dependency> <dependency> <groupId>org.eclipse.persistence</groupId> <artifactId>org.eclipse.persistence.jpa</artifactId> <scope>provided</scope> </dependency> </dependencies> </project>
這樣做的好處:統(tǒng)一管理項(xiàng)目的版本號(hào),確保應(yīng)用的各個(gè)項(xiàng)目的依賴和版本一致,才能保證測(cè)試的和發(fā)布的是相同的成果,因此,在頂層pom中定義共同的依賴關(guān)系。同時(shí)可以避免在每個(gè)使用的子項(xiàng)目中都聲明一個(gè)版本號(hào),這樣想升級(jí)或者切換到另一個(gè)版本時(shí),只需要在父類容器里更新,不需要任何一個(gè)子項(xiàng)目的修改;如果某個(gè)子項(xiàng)目需要另外一個(gè)版本號(hào)時(shí),只需要在dependencies中聲明一個(gè)版本號(hào)即可。子類就會(huì)使用子類聲明的版本號(hào),不繼承于父類版本號(hào)。
2、Dependencies
相對(duì)于dependencyManagement,所有生命在dependencies里的依賴都會(huì)自動(dòng)引入,并默認(rèn)被所有的子項(xiàng)目繼承。
3、區(qū)別
dependencies即使在子項(xiàng)目中不寫該依賴項(xiàng),那么子項(xiàng)目仍然會(huì)從父項(xiàng)目中繼承該依賴項(xiàng)(全部繼承)
dependencyManagement里只是聲明依賴,并不實(shí)現(xiàn)引入,因此子項(xiàng)目需要顯示的聲明需要用的依賴。如果不在子項(xiàng)目中聲明依賴,是不會(huì)從父項(xiàng)目中繼承下來(lái)的;只有在子項(xiàng)目中寫了該依賴項(xiàng),并且沒(méi)有指定具體版本,才會(huì)從父項(xiàng)目中繼承該項(xiàng),并且version和scope都讀取自父pom;另外如果子項(xiàng)目中指定了版本號(hào),那么會(huì)使用子項(xiàng)目中指定的jar版本。
import依賴范圍
import范圍只有在denpendencyManagement元素下才有效果
如果你想要把項(xiàng)目A項(xiàng)目的依賴用于另外一個(gè)項(xiàng)目就需要使用import范圍將這配置導(dǎo)入
<dependencyManagement> <dependencies> <dependency> <groupId>com.mvnbook.account</groupId> <artifactId>account-parent</artifactId> <version>1.0-SNAPSHOT</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
上述代碼中type的值為pom,import范圍由于其特殊性,一般都是指向打包類型為pom的模塊。如果有多個(gè)先忙,他們使用的版本都是一致的,則就可以定義一個(gè)使用
dependencyManagement專門管理依賴的POM,然后在各個(gè)項(xiàng)目中導(dǎo)入這些依賴管理配置
4、Maven約定優(yōu)于配置
它提出這一概念,為項(xiàng)目提供合理的默認(rèn)行為,無(wú)需不必要的配置。提供了默認(rèn)的目錄
src ——> 源代碼和測(cè)試代碼的根目錄
main 應(yīng)用代碼的源目錄
Java 源代碼
resources 項(xiàng)目的資源文件
test 測(cè)試代碼的源目錄
java 測(cè)試代碼
resources 測(cè)試的資源文件
target 編譯后的類文件、jar文件等
對(duì)于Maven約定優(yōu)于配置的理解,一方面對(duì)于小型項(xiàng)目基本滿足我們的需要基本不需要自己配置東西,使用Maven已經(jīng)配置好的,快速上手,學(xué)習(xí)成本降低;另一方面,對(duì)于不滿足我們需要的還可以自定義設(shè)置,體現(xiàn)了靈活性。配置大量減少了,隨著項(xiàng)目變的越復(fù)雜,這種優(yōu)勢(shì)就越明顯。
總結(jié)區(qū)別:
<dependencies>中的jar直接加到項(xiàng)目中,管理的是依賴關(guān)系(如果有父pom,子pom,則子pom中只能被動(dòng)接受父類的版本);<dependencyManagement>主要管理版本,對(duì)于子類繼承同一個(gè)父類是很有用的,集中管理依賴版本不添加依賴關(guān)系,對(duì)于其中定義的版本,子pom不一定要繼承父pom所定義的版本。
相關(guān)文章
MyBatis-Plus 修改和添加自動(dòng)填充時(shí)間方式
這篇文章主要介紹了MyBatis-Plus 修改和添加自動(dòng)填充時(shí)間方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08SpringBoot集成MyBatisPlus+MySQL的實(shí)現(xiàn)
MybatisPlus是國(guó)產(chǎn)的第三方插件, 它封裝了許多常用的CURDapi,免去了我們寫mapper.xml的重復(fù)勞動(dòng),本文主要介紹了SpringBoot集成MyBatisPlus+MySQL的實(shí)現(xiàn),感興趣的可以了解一下2023-10-10Spring Boot利用Docker快速部署項(xiàng)目的完整步驟
這篇文章主要給大家介紹了關(guān)于Spring Boot利用Docker快速部署項(xiàng)目的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Spring Boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07SpringBoot實(shí)現(xiàn)多個(gè)ApplicationRunner時(shí)部分接口未執(zhí)行問(wèn)題
這篇文章主要介紹了SpringBoot實(shí)現(xiàn)多個(gè)ApplicationRunner時(shí)部分接口未執(zhí)行問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05Java程序圖形用戶界面設(shè)計(jì)之標(biāo)簽組件
圖形界面(簡(jiǎn)稱GUI)是指采用圖形方式顯示的計(jì)算機(jī)操作用戶界面。與早期計(jì)算機(jī)使用的命令行界面相比,圖形界面對(duì)于用戶來(lái)說(shuō)在視覺(jué)上更易于接受,本篇精講Java語(yǔ)言中關(guān)于圖形用戶界面的標(biāo)簽組件部分2022-02-02Java封裝的實(shí)現(xiàn)訪問(wèn)限定符、包
封裝就是將數(shù)據(jù)和操作數(shù)據(jù)的方法進(jìn)行有機(jī)結(jié)合,隱藏對(duì)象的屬性(成員變量)和實(shí)現(xiàn)細(xì)節(jié),僅對(duì)外公開接口來(lái)和對(duì)象進(jìn)行交互,下面這篇文章主要給大家介紹了關(guān)于Java封裝實(shí)現(xiàn)訪問(wèn)限定符、包的相關(guān)資料2022-08-08