dependencyManagement與dependencies區(qū)別

一、dependencyManagement應(yīng)用場(chǎng)景

為了項(xiàng)目的正確運(yùn)行,必須讓所有的子模塊使用依賴項(xiàng)的統(tǒng)一版本,必須確保應(yīng)用的各個(gè)項(xiàng)目的依賴項(xiàng)和版本一致,才能保證測(cè)試的和發(fā)布的是相同的結(jié)果。在我們項(xiàng)目頂層的pom文件中,我們會(huì)看到dependencyManagement元素。通過它元素來管理jar包的版本,讓子項(xiàng)目中引用一個(gè)依賴而不用顯示的列出版本號(hào)。Maven會(huì)沿著父子層次向上走,直到找到一個(gè)擁有dependencyManagement元素的項(xiàng)目,然后它就會(huì)使用在這個(gè)dependencyManagement元素中指定的版本號(hào)。

父pom中dependencyManagement如下:

   <modules>
        <module>module1</module>
    </modules>
    <properties>
            <spring-version>3.1.1.RELEASE</spring-version>
    </properties>

    <dependencyManagement>
          <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
                <version>${spring-version}</version>
          </dependency>
    </dependencyManagement>

子模塊module1中dependency聲明如下所示:

   <dependencies>
            <dependency>
                  <groupId>org.springframework</groupId>
                  <artifactId>spring-web</artifactId>
            </dependency>
    </dependencies>

這樣做的好處:統(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)。

二、dependencies應(yīng)用場(chǎng)景

相對(duì)于dependencyManagement,如果在父pom文件中中通過dependencies引入jar,將默認(rèn)被所有的子模塊繼承。
子模塊如果希望有自己個(gè)性化的內(nèi)容,可以在子模塊中對(duì)于其中的某個(gè)屬性進(jìn)重新定義。
例如:
父pom中:

    <dependencyManagement>
       <dependencies>
          ....
          <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
                <version>3.1</version>
          </dependency>
          ....
      </dependencies>
    </dependencyManagement>

子模塊1的pod中:

<dependencies>
          ....
          <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
                <version>3.2</version>
              <exclusions>
                  <exclusion>
                        <groupId>com.alibaba</groupId>
                        <artifactId>fastjson</artifactId>
                    </exclusion>
              </exclusions>
          </dependency>
          ....
      </dependencies>

那么,子模塊1由于重新定義了spring-web的描述,因此子模塊將采用自己的依賴定義,而不再使用pom中默認(rèn)定義的。

三、dependencyManagement與dependencies區(qū)別

dependencyManagement里只是聲明依賴,并不實(shí)現(xiàn)引入,因此子項(xiàng)目需要顯式的聲明需要用的依賴。如果不在子項(xiàng)目中聲明依賴,是不會(huì)從父項(xiàng)目中繼承下來的;只有在子項(xiàng)目中寫了該依賴項(xiàng),并且沒有指定具體版本,才會(huì)從父項(xiàng)目中繼承該項(xiàng),并且version和scope都讀取自父pom;另外如果子項(xiàng)目中指定了版本號(hào),那么會(huì)使用子項(xiàng)目中指定的jar版本。

dependencies即使在子模塊中不寫該依賴項(xiàng),那么子模塊仍然會(huì)從父項(xiàng)目中繼承該依賴項(xiàng)(全部繼承)。

在實(shí)際的項(xiàng)目開發(fā)中,推薦在父pom中使用dependencyManagement對(duì)項(xiàng)目中使用到的依賴包進(jìn)行統(tǒng)一的管理。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容