美文网首页Android深入
AndroidStudio 管理依赖之BuildSrc——依赖A

AndroidStudio 管理依赖之BuildSrc——依赖A

作者: Deck方 | 来源:发表于2021-07-16 15:45 被阅读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()
     }
    
    1. 在buildSrc的module中创建src、main、java文件夹,目录格式如下图


      微信截图_20210716154051.png
    2. 在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}"
    }
    
    1. 在具体的mudole中引用
      mudole_one/build.gradle
    dependencies {
        implementation Deps.appcompat
        implementation Deps.material
        implementation Deps.retrofit
    }
    

    mudole_two/build.gradle

    dependencies {
        implementation Deps.appcompat
        implementation Deps.material
        implementation Deps.retrofit
    }
    

    最终实现如下效果


    动画.gif

    总结

    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 依赖更新将重新构建整个项目

    相关文章

      网友评论

        本文标题:AndroidStudio 管理依赖之BuildSrc——依赖A

        本文链接:https://www.haomeiwen.com/subject/zclbpltx.html