Android-Studio-之依赖方式详解(Compile, Provided...)

序言

我们在项目开发中,不可避免的需要使用到第三方的一些库,或者自己定义的一些lib,所以我们就需要在 build.gradle 文件添加对这些lib的依赖,代码如下:

1
2
3
4
5
6
dependencies {
compile fileTree(include: ['*.jar'], dir: 'libs')
compile 'com.android.support:support-v4:25.3.0'
...
provided files('jar/framework.jar')
}

可以看到上面使用到了两种依赖的方式:compile provided ,那么还有没有其它依赖方式?都有哪些?

dependencies

下面我们一起看看Studio给我们提供了那些依赖方式:

studio_dependencies

其实 Studio 已经提供了6种依赖方式:CompileProvidedAPKTest compileDebug compileRelease compile这里的名字和 dependencies 里面使用的命名是不用的 ,你可以添加几个试试看。那么问题来了,它们有什么不同?继续往下看

区别

Compile

Compile 是对所有的 build type 以及 favlors 都会参与编译并且打包到最终的 apk 文件中

Provided

Provided 是对所有的 build type 以及 favlors 只在编译时使用,类似eclipse中的external-libs,只参与编译,不打包到最终apk

APK

只会打包到 apk 文件中,而不参与编译,所以不能再代码中直接调用 jar 中的类或方法,否则在编译时会报错

Test compile

Test compile 仅仅是针对单元测试代码的编译以及最终打包测试apk时有效,而对正常的 debug 或者 release apk 包不起作用

Debug compile

Debug compile 仅仅针对 debug 模式的编译和最终的 debug apk 打包

Release compile

Release compile 仅仅针对 release 模式的编译和最终的 release apk 打包

我相信你看到这些应该是恍然大悟了吧,根据不同的场景使用不同的依赖方式,一定要严谨! 试问,还有其它的依赖方式吗?好像我在哪里看到过……

扩展

其实除了上面提供的6中依赖方式,还有一些支持的方式:android-aptannotationProcessor

Android-apt 是由一位开发者自己开发的 apt 框架,源代码托管在这里,随着 android Gradle 插件 2.2 版本的发布,Android Gradle 插件提供了名为 annotationProcessor 的功能来完全代替 android-apt ,自此 android-apt 作者在官网发表声明最新的 Android Gradle 插件现在已经支持 annotationProcessor,并警告和或阻止 android-apt ,并推荐大家使用 Android 官方插件 annotationProcessor。

关于注解的使用,不是本文的重点,重点是依赖所提供的功能。

android-apt & annotationProcessor

只在编译的时候执行依赖的库,但是库最终不打包到apk中。编译库中的代码没有直接使用的意义,也没有提供开放的 api调用,最终的目的是得到编译库中生成的文件,供我们调用。

总结

我曾经错误的将 compile 使用到了 provider 库,很悲剧的出现了方法数超过了65535,于是我开始改造项目,结果各种没效果,最后才了解到是依赖方式的问题,想想有多愚蠢!唉,年轻没经验啊!如果可以的话,尝试去使用每一种方式,看看有什么不同。

谢谢大爷~

  • 微信打赏二维码

    微信

  • 支付宝打赏二维码

    支付宝



目录
  1. 1. 序言
  2. 2. dependencies
  3. 3. 区别
    1. 3.1. Compile
    2. 3.2. Provided
    3. 3.3. APK
    4. 3.4. Test compile
    5. 3.5. Debug compile
    6. 3.6. Release compile
  4. 4. 扩展
    1. 4.1. android-apt & annotationProcessor
  5. 5. 总结
本站访问量   |   您是第 位.