gradle 使用 exclude 解决jar包冲突

本文介绍了解决Android项目中由于不同模块引用相同依赖的不同版本导致的冲突问题。通过使用Gradle命令检查依赖树来定位冲突源头,并展示了如何排除特定依赖以解决版本冲突。

项目经常会引用第三用依赖库,比如主module有glide,引用的第三方库也引用glide,glide版本不一致,就容易冲突。

解决方法:

1. 查看冲突的jar包;一眼能看出来的跳到第二步; 遇到隐藏比较深的就比较难受了,肉眼完全看不出来,此时打开AS的terminal控制台输入以下命令查看:

gradlew -q app:dependencies 查看依赖树;

比如: 

报错信息:

Duplicate class androidx.dynamicanimation.animation.DynamicAnimation$OnAnimationUpdateListener found in modules classes.jar (androidx.dynamicanimation:dynamicanimation:1.0.0) and classes.jar (dynamicanimation-1.1.0-alpha04.aar)
Duplicate class androidx.dynamicanimation.animation.DynamicAnimation$ViewProperty found in modules classes.jar (androidx.dynamicanimation:dynamicanimation:1.0.0) and classes.jar (dynamicanimation-1.1.0-alpha04.aar)

打开AS的terminal控制台输入:gradlew -q app:dependencies 

+--- com.airbnb.android:lottie:3.3.1
|    +--- androidx.appcompat:appcompat:1.0.0 -> 1.3.0-rc01 (*)
|    \--- com.squareup.okio:okio:1.17.4
+--- com.google.android.material:material:1.3.0
|    +--- androidx.annotation:annotation:1.0.1 -> 1.2.0
|    +--- androidx.appcompat:appcompat:1.1.0 -> 1.3.0-rc01 (*)
|    +--- androidx.cardview:cardview:1.0.0
|    |    \--- androidx.annotation:annotation:1.0.0 -> 1.2.0
|    +--- androidx.coordinatorlayout:coordinatorlayout:1.1.0 (*)
|    +--- androidx.constraintlayout:constraintlayout:2.0.1 -> 2.1.0-beta01 (*)
|    +--- androidx.core:core:1.2.0 -> 1.6.0-alpha01 (*)
|    +--- androidx.dynamicanimation:dynamicanimation:1.0.0
|    |    +--- androidx.core:core:1.0.0 -> 1.6.0-alpha01 (*)
|    |    +--- androidx.collection:collection:1.0.0 -> 1.1.0 (*)
|    |    \--- androidx.legacy:legacy-support-core-utils:1.0.0 (*)
|    +--- androidx.annotation:annotation-experimental:1.0.0
|    +--- androidx.fragment:fragment:1.0.0 -> 1.3.2 (*)
|    +--- androidx.lifecycle:lifecycle-runtime:2.0.0 -> 2.3.1 (*)
|    +--- androidx.recyclerview:recyclerview:1.0.0 -> 1.2.0-rc01 (*)

右键find, 输入关键字dynamicanimation:dynamicanimation,可以看到com.google.android.material:material:1.3.0 引入了它;

2.主module的build.gradle使用exclude过滤掉;

implementation ('com.google.android.material:material:1.3.0') {
    exclude group: "androidx.dynamicanimation", module: "dynamicanimation"
}

原文地址

在Java项目中,**JAR包冲突**是指多个依赖库引入了相同类名、包名或不同版本的同一库,导致运行时出现`NoSuchMethodError`、`ClassNotFoundException`、`LinkageError`等异常。解决JAR包冲突是构建稳定Java应用的重要步骤。 --- ### 一、解决JAR包冲突的方法 #### 1. 使用Maven或Gradle排除依赖 在Maven中可以通过`<exclusion>`标签排除冲突的依赖: ```xml <dependency> <groupId>some.group</groupId> <artifactId>some-artifact</artifactId> <version>1.0</version> <exclusions> <exclusion> <groupId>conflict.group</groupId> <artifactId>conflict-artifact</artifactId> </exclusion> </exclusions> </dependency> ``` 在Gradle使用: ```groovy implementation('some.group:some-artifact:1.0') { exclude group: 'conflict.group', module: 'conflict-artifact' } ``` #### 2. 统一版本号(BOM 或统一管理) 对于多个依赖使用相同库的情况,可以通过统一版本号来解决冲突: ```xml <dependencyManagement> <dependencies> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>30.1.1-jre</version> </dependency> </dependencies> </dependencyManagement> ``` 这样,所有引入`guava`的地方都会使用统一版本。 #### 3. 使用Shading(重命名包名) 对于无法排除或统一版本的冲突,可以使用Maven Shade插件对依赖包进行重命名: ```xml <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <executions> <execution> <phase>package</phase> <goals><goal>shade</goal></goals> <configuration> <relocations> <relocation> <pattern>com.google.guava</pattern> <shadedPattern>myshaded.guava</shadedPattern> </relocation> </relocations> </configuration> </execution> </executions> </plugin> ``` #### 4. 查看依赖树,定位冲突源 Maven中使用命令: ```bash mvn dependency:tree ``` Gradle使用: ```bash gradle dependencies ``` 通过查看依赖树可以快速找到冲突的模块和版本。 #### 5. 使用ClassLoader隔离(高级用法) 在某些复杂场景(如插件系统),可以使用自定义ClassLoader来隔离不同模块的依赖,避免类加载冲突。 --- ### 二、问题产生的原因 1. **多版本共存**:项目中引入了多个版本的相同库,JVM只会加载其中一个版本,导致类不兼容。 2. **依赖传递**:A依赖B,B依赖C,C又依赖D的不同版本,导致间接引入冲突。 3. **依赖覆盖**:构建工具默认使用第一个找到的依赖版本,忽略后续版本。 4. **类路径污染**:手动添加的lib目录中存在重复或冲突的jar。 --- ###
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值