Android Studio Gradle依赖冲突解决方法

时间:2021-05-21

前言

本文主要给大家介绍了Android Studio Gradle依赖冲突解决的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

1. 查看依赖树

./gradlew dependencies


2. 解决依赖冲突

一旦在构建中存在依赖冲突,开发人员需要决定哪个版本的库最终包含在构建中,有许多解决冲突的方法。

1. 逐个排除

compile('junit:junit:4.12'){ exclude group : 'org.hamcrest',module:'hamcrest-core'}//最终,如果我们向包含1.3版本到构建中,我们可以从“mockito"中排除他androidTestCompile('org.mockito:mockito-core:1.10.19'){ exclude group : 'org.hamcrest',module:'hamcrest-core'}

2. 显式依赖

在build.gradle中显示定义冲突的库,这是解决冲突的一种方式,在这种情况下,我们需要明确提出我们想要包含在任何一个配置的最终构建中的库的版本。

compile 'junit:junit:4.12'androidTestCompile 'org.mockito:mockito-core:1.10.19'androidTestCompile 'org.hamcrest:hamcrest-core:1.3'

如果多个依赖具有冲突版本的依赖或传递依赖的话,则不是从每个依赖性中排除模块,而是可以简单的使用期望的版本号来定义冲突依赖。

这种是一种更清洁的解决冲突的方法,但缺点是,当更新实际的依赖关系的时候,开发人员需要更新冲突的库。

3. 强制依赖

//在app.gradle 中的Android闭包中使用android{ configurations.all { resolutionStrategy.force 'com.android.support:appcompat-v7:28.0.0' resolutionStrategy.force 'com.android.support:support-v4:28.0.0' resolutionStrategy.force 'com.android.support:animated-vector-drawable:28.0.0' resolutionStrategy.force 'com.android.support:support-media-compat:28.0.0' }}//在build.gradle 中设置工程全局强制依赖allprojects{ configurations.all { resolutionStrategy.force 'com.android.support:appcompat-v7:28.0.0' resolutionStrategy.force 'com.android.support:support-v4:28.0.0' resolutionStrategy.force 'com.android.support:animated-vector-drawable:28.0.0' resolutionStrategy.force 'com.android.support:support-media-compat:28.0.0' }}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章