前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >详解Gradle依赖冲突解决方式

详解Gradle依赖冲突解决方式

作者头像
砸漏
发布2020-11-05 11:42:02
6.4K0
发布2020-11-05 11:42:02
举报
文章被收录于专栏:恩蓝脚本恩蓝脚本恩蓝脚本

问题

在Android开发中,相信遇到关于版本依赖的问题的同学有不少。虽然Android Studio一般都会自动帮我们去重,但是有时候去重失败了还是需要手动处理。在这里总结下自己长期遇到的各类问题的解决方式。

为了方便看效果,我们改下gradle解决策略为有版本冲突时自动失败,如下:

configurations.all {
 resolutionStrategy {
  failOnVersionConflict()
 }
}

当我们同时依赖不同版本rxjava时编译会报错如下:

解决方案

1.统一版本管理

当一个project下有多个module或library时很适合使用统一版本管理方式

创建config.gradle

在project目录下创建config.gradle文件,将需要统一管理的加在里面,如下:

ext {
 //Dependencies
 supportLibraryVersion = '25.3.1'
 okHttpVersion = '3.8.0'
 domainTestDependencies = [
   appcompatv7: "com.android.support:appcompat-v7:${supportLibraryVersion}",
   okHttp  : "com.squareup.okhttp3:okhttp:${okHttpVersion}"
 ]
}

在project下的build.gradle开头加入

apply from: "config.gradle"

module或library下引用版本

implementation rootProject.ext.dependencies["appcompatv7"]
implementation rootProject.ext.dependencies["okHttp"]

2.去除冲突依赖

当我们使用网上的一些开源库,并且自己项目里面也用到了不同的版本库时,我们可以在依赖的开源库中用exclude去除重复。

假如我们依赖的库是com.carlos.test:Test:1.0.0,里面用到了rxjava和我们module用到了不同版本,那么我们可以这样做:

 implementation ('com.carlos.test:Test:1.0.0') {
  exclude group: "io.reactivex.rxjava2",module: "rxjava"
  // exclude group: "io.reactivex.rxjava2:rxjava:2.1.11"
 }
 implementation 'io.reactivex.rxjava2:rxjava:2.1.13'

group为库的groupId,module为artifactId。我们也可以直接用注释中的方法指定具体的版本。

3.强制使用某版本依赖

我们也可以直接在策略里面强制使用某版本依赖

configurations.all {
 resolutionStrategy {
  force 'io.reactivex.rxjava2:rxjava:2.1.13'
 }
}

这样就是强制rxjava使用2.1.13版本了。

总结

三种方式各有不同场景,适合自己的是最好的,如有遗漏或错误欢迎指出。希望能互相交流学习。也希望大家多多支持ZaLou.Cn。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档