gradle 从 3.4 开始,compile 已经被废弃了,取而代之的是 api | implementation,俩个我们都可以用,但是肯定还是有区别的:
- api - 本地依赖时依赖不隔离,但是编译慢
- implementation - 本地依赖时依赖隔离,编译快
我们从 依赖隔离 | 编译速度 2个角度来看 api | implementation
依赖隔离
实际开始中我们有2种依赖方式:本地 project 依赖 | 远程 maven 依赖
我们举这样一个例子 app module A 依赖 module B ,module B 又依赖了 module C ,module C 又依赖了 module D
1. 本地 project 依赖
- api - A -> D 要是都是 api 的本地依赖方式,那么 A 中可以使用 B,C,D 的 API
- implementation - A -> D 要是都是 implementation 的本地依赖方式,那么 A 就只能使用 B 的 API,C,D 的 API 是找不到的
2. 远程 maven 依赖
- implementation 就没代码隔离的作用了,B,C,D 的 API A 都能使用
3. 远程和本地依赖混用
- 若 A-> B -> C -> D 之间都是远程依赖,implementation 就起不到代码隔离的作用了,B,C,D 的 API A 都能使用
- 若 C -> D 之间是远程依赖,但 A-> B -> C 之间是本地依赖, 使用 implementation 时,B 可以拿到 D 的 api,但是 A 就拿不到 D 的 api 了
编译速度
在本地依赖时 implementation 可以起到代码隔离的作用,自然编译的速度就快,还是 A-> B -> C -> D 举例,若是 D 更新了,那么只有 C,D 是需要重新编译的。但是一旦我们使用了 API 的依赖方式,那么 ABCD 都需要重新编译