Android Studio 管理依赖BuildSrc

发布于:2022-11-05 ⋅ 阅读:(580) ⋅ 点赞:(0)

传统的依赖管理

过去通过gradle的ext属性来维护依赖库一个map

ext {
    dependencies = [
           "appcompat"       : "androidx.appcompat:appcompat:1.2.0",
           "recyclerview"      : "androidx.recyclerview:recyclerview:1.2.0",
    ]
}

然后再相应的module中添加具体的引用

implementation rootProject.ext.dependencies[appcompat]
implementation rootProject.ext.dependencies[recyclerview]

这种方法实现了依赖库的集中管理,但是缺少IDE的支持在添加依赖库的时候IDE不能自动补全

buildSrc方式管理依赖库

  • 什么是buildSrc
当你运行Gradle时,它会检查项目中是否存在一个名为buildSrc的目录。
然后Gradle会自动编译并测试这段代码,并将其放入构建脚本的类路径中。您不需要提供任何进一步的操作提示。
  • 使用buildSrc
  1. 创建与app同级的文件夹buildSrc
  2. 在buildSrc文件夹里创建名为build.gradle.kts的文件,并添加如下代码
     plugins {
         `kotlin-dsl`
     }
    
     repositories {
           mavenCentral()
     }
  3. 在buildSrc的module中创建src、main、java文件夹,目录格式如下图
  4. 在java目录中创建类Deps.kt 并添加相应的依赖管理

    object V{
        const val appcompat="1.2.0"
        const val retrofit="2.9.0"
        const val material="1.3.0"
    }
    
    object Deps {
        const val appcompat= "androidx.appcompat:appcompat:${V.appcompat}"
        const val retrofit= "com.squareup.retrofit2:retrofit:${V.retrofit}"
        const val material= "com.google.android.material:material:${V.material}"
    }

总结

buildSrc 方式管理依赖大大增加了依赖管理的便捷性和易用性

优点

  • 共享 buildSrc 库工件的引用,全局管理依赖
  • 支持 AndroidStudio 自动补全,实现Autocomplete
  • 支持依赖库的点击跳转

缺点

A change in buildSrc causes the whole project to become out-of-date. 
Thus, when making small incremental changes, the --no-rebuild command-line option is often helpful to get faster feedback.
Remember to run a full build regularly or at least when you’re done, though.
buildSrc的更改会导致整个项目过时,因此,在进行小的增量更改时,
-- --no-rebuild命令行选项通常有助于获得更快的反馈。不过,请记住要定期或至少在完成后运行完整版本
  • 缺点就是buildSrc 依赖更新将重新构建整个项目


网站公告

今日签到

点亮在社区的每一天
去签到