安卓依赖冲突处理

本文详细解析Android应用中模块依赖的声明、打包时的处理策略,以及重复依赖引发的错误及其解决方法。重点讲解了Google Play Services的版本管理和优先级设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、模块依赖

这里引用一下谷歌链接:

https://developer.android.com/studio/build/dependencies#google-maven

当我们接入第三方sdk的时候需要调用第三方的代码。那么第三方的代码从哪里来?我们可以通过在gradle文件中声明dependencies来获取第三方的代码库如:

repositories {
        mavenCentral()
        google()
        jcenter()
        maven { url 'https://jitpack.io' }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar', '*.aar'])
     // 谷歌登录部分
    implementation 'com.google.android.gms:play-services-auth:19.2.0'
}

我在app的Gradle中声明:这里repositories代表引用从哪里下载 ,下面的 implementation fleTree(dir: 'libs', include:['*.jar', '*.aar']) 表示引用了 libs文件夹下面所有的jar和 aar文件, 最后一句表示需要下载谷登录的19.2.0版本的代码。

二、打包时如何处理依赖

这里引用一下谷歌的链接:https://developer.android.com/studio/build/dependencies#dependency-order

gradle中我们在dependencies声明依赖的顺序就代表依赖的优先级,写在上面的依赖优先级高于写在下面依赖的优先级:

dependencies {
   // 谷歌登录部分
    implementation 'com.google.android.gms:play-services-auth:19.2.0'
    // 谷歌支付
    implementation 'com.android.billingclient:billing:4.0.0'
    implementation 'com.google.android.gms:play-services-wallet:18.1.2'
}
如果我这么写就代表着谷歌登录的优先级高于谷歌支付的优先级,如果支付引用的代码和登录引用的代码有重复,当支付的代码对应的版本较低时,就会使用登录的代码打包和编译。

三、为什么依赖重复后会有报错

重复依赖报错:https://developer.android.com/studio/build/dependencies#resolution_errors

版本不同报错:https://developer.android.com/studio/build/dependencies#custom_dep_resolutions

重复依赖的报错我们可以通过排除的方式来解决重复依赖报错:

exclude group: 'com.google.guava', module: 'listenablefuture'

重复依赖的报错我们可以通过更新较旧的库来解决:
       目的一:使两者版本一致

        目的二:使另外一个的版本更高一些,用安卓自带的版本冲突处理策略来解决问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值