Gradle transitive = true

本文介绍如何在Gradle项目中管理直接与间接依赖,包括使用transitive=true下载依赖库及其依赖,排除特定的transitive dependencies,以及如何解决版本冲突。

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

transitive = true

transitive dependencies 被称为依赖的依赖,称为“间接依赖”比较合适。

compile('com.meituan.android.terminus:library:6.6.1.16@aar'){
        transitive = true
        exclude module: 'hotel_model'
        exclude module: 'base_model'
    }

在后面加上@aar,意指你只是下载该aar包,而并不下载该aar包所依赖的其他库,那如果想在使用@aar的前提下还能下载其依赖库,则需要添加transitive=true的条件。
排除 transitive dependencies
通过configuration或者dependency可以除去 transitive dependencies:

build.gradle

configurations {
    compile.exclude module: 'commons'
    all*.exclude group: 'org.gradle.test.excludes', module: 'reports'
}
dependencies {
    compile("org.gradle.test.excludes:api:1.0") {
        exclude module: 'shared'
    }
}

如果在configuration中定义一个exclude,那么所有依赖的transitive dependency (指定的)都会被去除。
定义exclude时候,或只指定group, 或只指定module名字,或二者都指定。

不是所有的transitive dependency 都可以被去除的,如runtime时候使用到的。一般来说,runtime时候用不到的,或者目标环境及平台已经包含该依赖的可以执行exclude去除。

那exclude选per-dependency还是per-configuration?,大多数情况我们都选用per-configuration,下面是一些使用exclude的典型场合:
* 有licensing问题
* 从远程仓库上无法获取到依赖
* runtime时候用不到
* 有版本冲突

exclude的疑问

 exclude module: 'base_model'

exclude group:'com.name.group' module:'base_model'

的区别是?

经过测试,二者的作用是完全一样的。
这里写图片描述

在上面图示中会有这么几种标记:

版本 : 唯一的依赖。
版本():还存在该库其他版本的依赖或者间接依赖,并且默认选择()所标注的版本。
版本1->版本2(*):还存在该库其他版本的依赖或者间接依赖,并且选择 版本2。

force=true

compile('com.squareup.okhttp:okhttp-mt:2.5.0') {
        force = true
}

如上,我们在依赖okhttp的时候很可能发生冲突,就比如依赖的依赖中也包含了okhttp,这种场合下,就会产生版本冲突的问题,加上force = true表明的意思就是即使在有依赖库版本冲突的情况下坚持使用被标注的这个依赖库版本。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值