行业报告 AI展会 数据标注 标注供求
数据标注数据集
主页 > 技术社区 > 移动端 > 正文

Android中依赖版本统一管理

前言

在Android的实际开发中,我们会经常使用到多Module开发,而当我们修改一些版本信息或者SDK升级时,可能涉及多个Module都需要修改。

显然逐个修改Module中的build.gradle文件是非常繁杂而且容易出错的一件事情,基于此种
情况,我们需要对整个工程中的配置和依赖进行统一管理。

一、建立单独config.gradle文件统一配置

我们可以在项目根目录下建立config.gradle文件,然后在项目的build.gradle文件中中引入:

    apply from:"config.gradle"
    buildscript {
    ...
    }

BuildConfig管理

首先是对BuildConfig的管理,如buildToolsVersion,targetSdkVersion等基本的config信息。

config.gradle文件中添加:

ext {
    android = [
            sourceCompatibilityVersion: JavaVersion.VERSION_1_8,
            targetCompatibilityVersion: JavaVersion.VERSION_1_8,
            minSdkVersion             : 21,
            targetSdkVersion          : 28,
            compileSdkVersion         : 30,
            buildToolsVersion         : "28.0.3",
            versionCode               : 1,
            versionName               : "1.0.0"
    ]
}

然后在Module里的build.gradle文件中可以使用上述参数:

    compileSdkVersion rootProject.ext.android["compileSdkVersion"]
    buildToolsVersion rootProject.ext.android["buildToolsVersion"]

    defaultConfig {
        applicationId "com.example.demowork1"
        minSdkVersion rootProject.ext.android["minSdkVersion"]
        targetSdkVersion rootProject.ext.android["targetSdkVersion"]
        versionCode rootProject.ext.android["versionCode"]
        versionName rootProject.ext.android["versionName"]
        ...
    }

三、依赖管理

我们在多个Module中可以存在一些相同的依赖,如果我们对这些依赖升级,则需要多个Module配置都更改,容易疏漏。因此对依赖进行统一管理是十分有必要的,我们同样可以使用config.gradle文件实现依赖管理。

config.gradle文件中添加各个依赖的版本及库名称,使用versions统一管理依赖的版本,dependencies统一管理引入的依赖,详细代码如下:

    versions = [
            // androidx libs
            appCompatVersion              : "1.0.2",
            recyclerViewVersion           : "1.2.0",
            constraintLayoutVersion       : "2.0.4",
            materialVersion               : "1.2.1"
        ]
    dependencies = [
            // androidx libs
            appcompat                   : "androidx.appcompat:appcompat:${versions.appCompatVersion}",
            recyclerView                : "androidx.recyclerview:recyclerview:${versions.recyclerViewVersion}",
            constraintLayout            : "androidx.constraintlayout:constraintlayout:${versions.constraintLayoutVersion}",
            material                    : "com.google.android.material:material:${versions.materialVersion}"
        ]

完成在config中的配置后,我们就可以在Module的build.gradle中引用上述的依赖配置:

dependencies {

    implementation rootProject.ext.dependencies.appcompat
    implementation rootProject.ext.dependencies.okhttp

    implementation rootProject.ext.dependencies.recyclerView
    implementation rootProject.ext.dependencies.constraintLayout
    implementation rootProject.ext.dependencies.material
}

我们的config.build是在根目录下,所有Module中都可以引入对应的依赖,这样在升级SDK时直接更新config中的配置即可,达到一个统一管理的效果。

总结

通过自定义config.build文件可以实现依赖的统一管理,对于组件化开发的工程提供维护便利。


 

微信公众号

声明:本站部分作品是由网友自主投稿和发布、编辑整理上传,对此类作品本站仅提供交流平台,转载的目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,不为其版权负责。如果您发现网站上有侵犯您的知识产权的作品,请与我们取得联系,我们会及时修改或删除。

相关推荐:

网友评论:

发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 验证码:点击我更换图片
SEM推广服务

Copyright©2005-2026 Sykv.com 可思数据 版权所有    京ICP备14056871号

关于我们   免责声明   广告合作   版权声明   联系我们   原创投稿   网站地图  

可思数据 数据标注行业联盟

扫码入群
扫码关注

微信公众号

返回顶部