maven pom的繼承功能的使用, 詳解

介紹

繼承這個功能我在maven的官方文檔中并沒有看到它的具體使用場景,只是簡單的介紹了它的使用方法.
pom的繼承和類的繼承在概念上來講其實是一樣的,子pom可以繼承父pom的信息,也就是將子pom的部分代碼抽取,然后集中到父pom中.
所以繼承可以消除重復代碼,降低pom復雜度,降低理解和管理工程的難度. 我們可以將該功能用在工程的多模塊管理上.

繼承的使用方法(例子來自maven官方文檔)

父pom

<project>
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.mycompany.app</groupId>
  <artifactId>my-app</artifactId>
  <version>1</version>
</project>

子pom

<project>
  <parent>
    <groupId>com.mycompany.app</groupId>
    <artifactId>my-app</artifactId>
    <version>1</version>
    <relativePath>[父pom之于子pom的相對路徑]</relativePath>
  </parent>
  <modelVersion>4.0.0</modelVersion>
  <artifactId>my-module</artifactId>
</project>

當父pom在子pom的上一級目錄時,比如像下面這樣,relativePath該標簽可以省略

.
|-- my-module
| `-- pom.xml
`-- pom.xml

注:我在查詢資料的時候,有個博客中說在繼承中父pom需要將packaging標簽修改為pom,我認為是不用的.
在官方文檔中也沒有說需要這樣,只是在聚合功能,聚合+繼承功能時需要修改packaging標簽為pom. 不過我并沒有對此進行驗證, 大家可以自己驗證一下.

子pom將會繼承的信息

子pom將會繼承父pom如下信息:
dependencies (依賴)
developers and contributors (開發(fā)人員和貢獻值)
plugin lists (including reports) (插件列表包括報告)
plugin executions with matching ids (插件執(zhí)行和匹配的ids)
plugin configuration (插件配置)
resources (資源)

詳細的繼承信息在這里就不寫了, 我貼幾條別人寫的鏈接吧
Maven工程的POM繼承
Maven POM元素繼承
maven的聚合和繼承詳解

dependencyManagement 和 pluginManagement

通過繼承功能我們可以將所有子模塊中需要用到的依賴包,插件等都集中到父pom統(tǒng)一管理.
這樣可以避免不同的子模塊依賴不同版本的jar包,插件.如果需要進行版本升級也可以很方便的進行,不需要一個個去修改pom.
繼承功能會繼承父pom的所有依賴和插件,但有時候并不是每個子pom都需要,只是部分子pom需要,那我們將所有依賴和插件都扔到子pom中就不合適,
對于這種情況maven提供了dependencyManagement標簽用于管理依賴,pluginManagement用于管理插件

dependencyManagement的使用方法

dependencyManagement標簽中的依賴不會直接添加到子pom, 如果子pom需要使用該依賴, 就需要在子pom中進行聲明,
這樣做雖然沒有消除多少重復代碼, 但可以統(tǒng)一管理jar包的版本, 降低管理復雜度.

使用方法如下:
父pom

<project>

    ...

    <dependencyManagement>
        <dependencies>
            <dependency>
                ...
            </dependency>

            ...

        </dependencies>
    </dependencyManagement>
</project>

子pom直接在project下的dependencies標簽中添加即可,不用指定版本

<project>

    ...

    <dependencies>

        ...

        <dependency>
            <groupId>[groupId]</groupId>
            <artifactId>[artifactId]</artifactId>
        </dependency>
           
    </dependencies>

</project>

pluginManagement的使用方法

pluginManagement用法和上面的差別不大
父pom

<build>

    ...

    <pluginManagement>
        <plugins>

            ...

            <plugin>
                ...
            </plugin>
        </plugins>
    </pluginManagement>
</build>

子pom

<build>

    ...

    <plugins>

        ...

        <plugin>
            <groupId>[groupId]</groupId>
            <artifactId>[artifactId]</artifactId>
        </plugin>
    </plugins>
</build>

參考資料

Maven POM元素繼承
maven的聚合和繼承詳解

maven pom官方文檔
maven pom中文文檔

注解

該博客只是為了學習新知識和梳理知識,如有錯漏,還請大家指正.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容