關注“Java後端技術棧”
回覆“面試”獲取最新資料
回覆“加羣”邀您進技術交流羣
# 何爲依賴衝突
Maven是個很好用的依賴管理工具,但是再好的東西也不是完美的。Maven的依賴機制會導致Jar包的衝突。舉個例子,現在你的項目中,使用了兩個Jar包,分別是A和B。現在A需要依賴另一個Jar包C,B也需要依賴C。但是A依賴的C的版本是1.0,B依賴的C的版本是2.0。這時候,Maven會將這1.0的C和2.0的C都下載到你的項目中,這樣你的項目中就存在了不同版本的C,這時Maven會依據依賴路徑最短優先原則,來決定使用哪個版本的Jar包,而另一個無用的Jar包則未被使用,這就是所謂的依賴衝突。
在大多數時候,依賴衝突可能並不會對系統造成什麼異常,因爲Maven始終選擇了一個Jar包來使用。但是,不排除在某些特定條件下,會出現類似找不到類的異常,所以,只要存在依賴衝突,在我看來,最好還是解決掉,不要給系統留下隱患。
# 解決方法
解決依賴衝突的方法,就是使用Maven提供的標籤,標籤需要放在標籤內部,就像下面這樣:
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.10.0</version>
<exclusions>
<exclusion>
<artifactId>log4j-api</artifactId>
<groupId>org.apache.logging.log4j</groupId>
</exclusion>
</exclusions>
</dependency>
log4j-core本身是依賴了 log4j-api的,但是因爲一些其他的模塊也依賴了 log4j-api,並且兩個 log4j-api版本不同,所以我們使用標籤排除掉 log4j-core所依賴的 log4j-api,這樣Maven就不會下載 log4j-core所依賴的 log4j-api了,也就保證了我們的項目中只有一個版本的 log4j-api。
# Maven Helper
看到這裏,你可能會有一個疑問。如何才能知道自己的項目中哪些依賴的Jar包衝突了呢?Maven Helper這個InteliJ IDEA的插件幫我們解決了這個問題。插件的安裝方法我就不講了,既然你都會Maven了,我相信你也是會安裝插件的。
在插件安裝好之後,我們打開pom.xml文件,在底部會多出一個Dependency Analyzer選項
點開這個選項
找到衝突,點擊右鍵,然後選擇Exclude即可排除衝突版本的Jar包。
# 小技巧
除了使用Maven Helper查看依賴衝突,也可以使用IDEA提供的方法——Maven依賴結構圖,打開Maven窗口,選擇Dependencies,然後點擊那個圖標(Show Dependencies)或者使用快捷鍵(Ctrl+Alt+Shift+U),即可打開Maven依賴關係結構圖
在圖中,我們可以看到有一些紅色的實線,這些紅色實線就是依賴衝突,藍色實線則是正常的依賴。
來源:https://urlify.cn/mAj6Nj
推薦閱讀
面試被問:運行一個HelloWorld程序JVM都經歷了什麼
目前10000+ 人已關注我們