详解Gradle依赖冲突解决方式
问题
在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版本了。
总结
三种方式各有不同场景,适合自己的是最好的,如有遗漏或错误欢迎指出。希望能互相交流学习。也希望大家多多支持脚本之家。
相关文章
详解Android Studio安装ButterKnife插件(手动安装)
这篇文章主要介绍了详解AndroidStudio安装ButterKnife插件(手动安装),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-08-08Android中使用ContentProvider管理系统资源的实例
这篇文章主要介绍了Android中使用ContentProvider管理系统资源的实例,讲解了ContentProvider对系统中联系人及多媒体资源的管理例子,需要的朋友可以参考下2016-04-04AndroidGUI27中findViewById返回null的快速解决办法
这篇文章主要介绍了AndroidGUI27中findViewById返回null的快速解决办法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下2016-06-06Android Zipalign工具优化Android APK应用
本文主要介绍Android Zipalign工具优化Android APK应用,这里整理了相关资料及简单优化实例,有需要的小伙伴可以参考下2016-09-09Android中通过样式来去除app的头及界面全屏(备忘)的实现方法
这篇文章主要介绍了Android中通过样式来去除app的头及界面全屏(备忘)的相关资料,需要的朋友可以参考下2016-12-12
最新评论