热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

依赖版本管理的几种方式

讲下如何管理依赖版本,以及如何管理正式环境与测试环境的变量,最后讲下如何封装并控制依赖版本。管理版本的方式不止我列出的几种,我只是写出了

讲下如何管理依赖版本,以及如何管理正式环境与测试环境的变量,最后讲下如何封装并控制依赖版本。

管理版本的方式不止我列出的几种,我只是写出了个人认为比较方便的方法。也是自用的方法,仅供各位高工参考。如有不正还请指出!

一. 使用gradle文件管理如dependent.gradle

dependent.gradle中定义一些依赖库的版本,然后在项目的跟build.gradle中引入,这样全部模块都可以使用到dependent.gradle中的值。
dependent.gradle:

ext {deps = [//android和kt依赖资源android: ["appcompat" : "androidx.appcompat:appcompat:1.3.1","design" : "com.google.android.material:material:1.4.0","constraint_layout" : "androidx.constraintlayout:constraintlayout:2.0.3","recyclerview" : "androidx.recyclerview:recyclerview:1.2.0",'fragment_ktx' : 'androidx.fragment:fragment-ktx:1.3.6','multidex' : 'androidx.multidex:multidex:2.0.1',"kt_ktx" : 'androidx.core:core-ktx:1.6.0',"ktx_coroutines_core" : 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.5.2',"ktx_coroutines_android": 'org.jetbrains.kotlinx:kotlinx-coroutines-android:1.5.2',"lifecycle" : 'androidx.lifecycle:lifecycle-runtime-ktx:2.3.1',"lifecycle_ktx" : 'androidx.lifecycle:lifecycle-livedata-ktx:2.3.1',"junit" : 'junit:junit:4.12',"test_junit" : 'androidx.test.ext:junit:1.1.1',"test_espresso" : 'androidx.test.espresso:espresso-core:3.2.0',],//第三方support: ["glide" : 'com.github.bumptech.glide:glide:4.12.0',"glide_annotation" : 'com.github.bumptech.glide:annotations:4.12.0',"glide_integration" : 'com.github.bumptech.glide:okhttp3-integration:4.12.0',"glide_compiler" : 'com.github.bumptech.glide:compiler:4.12.0',"gif_drawable" : 'pl.droidsonroids.gif:android-gif-drawable:1.2.10',"hilt" : 'com.google.dagger:hilt-android:2.38.1',"hilt_kapt" : 'com.google.dagger:hilt-android-compiler:2.38.1',"arouter" : 'com.alibaba:arouter-api:1.5.2',"arouter_kapt" : 'com.alibaba:arouter-compiler:1.5.2',"retrofit2" : 'com.squareup.retrofit2:retrofit:2.9.0',"retrofit_gson" : 'com.squareup.retrofit2:converter-gson:2.9.0','gson_factory' : 'com.github.getActivity:GsonFactory:5.2', //Gson转换容错处理...]]versions = ['minSdk' : 21,'targetSdk' : 31,'compileSdk': 31,]}

build.gradle:

//直接引用
apply from: "dependent.gradle"
apply from: "config.gradle"
...

在Lib库中就能直接使用了,如下:

apply from: "../lib_default_config.gradle"
apply plugin: 'dagger.hilt.android.plugin'dependencies {//noinspection GradleDependencyapi "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version"//路由api project(':cs_router')//AndroidXapi deps.android.appcompatapi deps.android.constraint_layoutapi deps.android.recyclerviewapi deps.android.designapi deps.android.multidex...

二. 使用java-gradle-plugin插件的方式管理

这一种方法,使用插件的方式,可以在依赖的地方跳转到指定的位置,并且由于不是在gradle文件中修改的,所以修改值之后可以不需要build。

代码如上,需要在项目中创建一个projcet。定义它的build.gradle为java-gradle-plugin类型。

buildscript {repositories {jcenter()google()}dependencies {classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:1.4.21"}
}apply plugin: 'kotlin'
apply plugin: 'java-gradle-plugin' //既不是lib也不是application,指定类型为gradle插件repositories {jcenter()google()
}dependencies {implementation gradleApi()implementation "org.jetbrains.kotlin:kotlin-gradle-plugin:1.4.21"
}compileKotlin {kotlinOptions {jvmTarget = "1.8"}
}
compileTestKotlin {kotlinOptions {jvmTarget = "1.8"}
}gradlePlugin {plugins {version {id = 'com.hongyegroup.version'implementationClass = 'com.hongyegroup.version.DependencyVersionPlugin'}}
}

入口文件:

class DependencyVersionPlugin : Plugin {override fun apply(project: Project) {//入口文件-空实现}
}

定义版本的单例类:

object BuildConfig {const val compileSdkVersion = 29const val buildToolsVersion = "30.0.1"const val minSdkVersion = 21const val targetSdkVersion = 29const val versionCode = 100const val versionName = "1.0.0"
}

使用的时候:可以很清楚的看到不同的依赖方式都已经注明。

android {compileSdkVersion BuildConfig.compileSdkVersionbuildToolsVersion BuildConfig.buildToolsVersiondefaultConfig {minSdkVersion versions.minSdk //使用dependent.gradle的依赖无法跳转targetSdkVersion versions.targetSdk //修改gradle文件中的值,需要buildversionCode BuildConfig.versionCode //使用version方式管理的依赖,可以跳转versionName BuildConfig.versionName //修改其中的值,无需buildtestInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"consumerProguardFiles 'consumer-rules.pro'multiDexEnabled truevectorDrawables.useSupportLibrary = true}
}

三. gradle配合BuildConfig管理正式环境和测试环境变量

相信很多同学都是这么管理正式环境与测试环境的吧。

public class Constants {// //测试环境
// public static final String API_BASE_URL = "http://baidu-api-dev.guabean.com";
// //IM测试环境
// public static final int TIMSDK_APPID = 123456789;//正式环境public static final String API_BASE_URL = "http://api.baidu.com";//IM正式环境public static final int TIMSDK_APPID = 987654321;//推送的正式环境//推送的测试环境//Web的正式环境 等等
}

一旦项目大了,需要配置的东西多了,那切换环境的时候岂不是要断手。其实我们可以在gradle中配置,配合BuildConfig的方式来配置正式与测试环境的变量。

config.gradle:

ext {// isLocalRelease = true //本地打包环境 release设置trueisLocalRelease = false //本地打包环境 debug设置false// isReleaseUrl = true //使用的服务器域名的环境, 正式环境设置trueisReleaseUrl = false //使用的服务器域名的环境,测试环境设置false (线上环境)// 测试环境的域名baseUrl_dev = 'http://baidu-api-dev.guabean.com'// 正式环境的域名baseUrl_relese = 'https://api.baidu.com'//极光测试环境keyjpush_key_dev = '12345678'//极光正式环境keyjpush_key_relese = '87654321'//Web地址等等
}

使用:我们在底层库中,拿到它的全部值,根据是否是测试环境,来配置不同的值。 如cptServer的build.gradle:

apply from: "../lib_default_config.gradle"
apply plugin: 'dagger.hilt.android.plugin'android {defaultConfig {//读取配置表的值boolean mIsReleaseUrl = rootProject.ext.isReleaseUrl//判断是正式环境还是测试环境if (mIsReleaseUrl) {String baseUrlRelese = rootProject.ext.baseUrl_relesebuildConfigField 'String', 'Base_Url', "\"${baseUrlRelese}\""} else {String baseUrlDev = rootProject.ext.baseUrl_devbuildConfigField 'String', 'Base_Url', "\"${baseUrlDev}\""}}}dependencies {//底层api project(':cs_baselib')
}

当我们使用的时候:就可以直接拿BuildConfig中的值

public class Constants {public static final String BASE_URL = BuildConfig.Base_Url;...
}

我们切换环境的时候,也只需要修改config.gradle的环境true和false就行了。这样就算再多的web和api key都可以很方便的管理。

四. gradle文件的继承与封装,完全的统一组件的依赖版本

组件化开发的过程中,各个组件的build.gradle依赖不同的库,导致各个版本不同,容易导致不兼容的问题。

如图,我们封装了gradle的内部实现,不同的级别模块依赖不同的gradle。

例如lib库依赖 lib_default_config.gradle。

子组件依赖模块 module_default_config.gradle。

运行模块如app或者独立子模块运行模块依赖 runing_default_config.gradle。

lib_base_config.gradle中定义了常规的gradle配置,和一些指定版本的配置。这个是用于其他的gradle继承的,一般不单独使用,代码如下:

apply plugin: 'dagger.hilt.android.plugin'//基类的gradle配置
kapt { //ARouter的编译配置arguments {arg("AROUTER_MODULE_NAME", project.getName())}
}android {compileSdk versions.compileSdkdefaultConfig {minSdk versions.minSdktargetSdk versions.targetSdkversionCode 1versionName "1.0"testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"consumerProguardFiles 'consumer-rules.pro'multiDexEnabled truevectorDrawables.useSupportLibrary = truejavaCompileOptions { //Hilt的编译配置annotationProcessorOptions {arguments += ["foo" : "bar"]}}}buildTypes {release {minifyEnabled falsemultiDexKeepProguard file('multidex-config.pro')proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'}debug {multiDexKeepProguard file('multidex-config.pro')}}compileOptions {sourceCompatibility JavaVersion.VERSION_1_8targetCompatibility JavaVersion.VERSION_1_8}kotlinOptions {freeCompilerArgs = ['-Xjvm-default=enable']jvmTarget = JavaVersion.VERSION_1_8useIR = true}lintOptions {checkReleaseBuilds false}packagingOptions {resources {excludes += '/META-INF/{AL2.0,LGPL2.1}'}}}configurations.all {resolutionStrategy.force 'androidx.multidex:multidex:2.0.1'resolutionStrategy.force 'androidx.annotation:annotation:1.2.0'resolutionStrategy.force 'androidx.transition:transition:1.3.1'resolutionStrategy.force 'androidx.lifecycle:lifecycle-common:2.3.1'resolutionStrategy.force 'androidx.recyclerview:recyclerview:1.2.0'
}dependencies {api fileTree(dir: 'libs', include: ['*.jar'])//每个模块都要实现的依赖//TesttestImplementation deps.android.junitandroidTestImplementation deps.android.test_junitandroidTestImplementation deps.android.test_espresso//依赖注入implementation deps.support.hiltkapt deps.support.hilt_kapt//ARouter路由implementation (deps.support.arouter){exclude group: 'com.android.support'exclude group: 'androidx.appcompat'exclude group: 'com.google.android.material'exclude group: 'androidx.activity'}//ARouter的注解处理器kapt deps.support.arouter_kapt}

lib_default_config.gradle的配置,用于Lib库的使用

//底层依赖库的gradle配置,可以依赖这个配置 再配置别的依赖
apply plugin: 'com.android.library'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-kapt'apply from: rootProject.file('lib_base_config.gradle') //重复的配置统一由基类提供

使用:比如我引用一个lib_popup库,它的build.gradle:

apply from: "../lib_default_config.gradle"dependencies {//继承了之前的dependencies,再定义一些我需要的依赖库implementation deps.android.appcompatapi deps.support.easy_adapter
}

module_default_config.gradle的配置,用于子组件的使用

//默认的模块初始化gradle配置,可以依赖这个配置 再配置别的依赖
apply plugin: 'com.android.library'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-kapt'apply from: rootProject.file('lib_base_config.gradle') //重复的配置统一由基类提供android {buildFeatures {dataBinding = trueviewBinding = true}
}dependencies {implementation project(':cs_cptServices') //Module模块默认添加Service模块的
}

如cpt_newsfeed,朋友圈组件的build.gradle

apply from: "../module_default_config.gradle"dependencies {//九宫格控件implementation project(':cs_ninegrid')
}

runing_default_config.gradle的配置用于子组件独立运行模块或者app模块。

//运行模块初始化gradle配置,可以依赖这个配置 再配置别的依赖
apply plugin: 'com.android.application'
apply plugin: 'kotlin-android'
apply plugin: 'kotlin-kapt'
apply plugin: 'dagger.hilt.android.plugin'//运行模块可以添加路由
apply plugin: 'com.alibaba.arouter'apply from: rootProject.file('lib_base_config.gradle') //重复的配置统一由基类提供android {defaultConfig {versionCode 100versionName "1.0.0"applicationId "com.hongyegroup.running"}buildFeatures {dataBinding = trueviewBinding = true}
}dependencies {//依赖注入implementation deps.support.hiltkapt deps.support.hilt_kaptimplementation project(':cs_cptServices') //运行模块默认添加Service模块的
}

使用的时候,如app模块,程序的入口,它的build.gradle如下:

apply from: "../runing_default_config.gradle"android {defaultConfig {versionCode 100versionName "1.0.0"applicationId "com.xxgroup.xxapp"}
}dependencies {//依赖模块implementation project(':cs_cptServices')implementation project(':cpt_auth')implementation project(':cpt_main')implementation project(':cpt_parttime')implementation project(':cpt_newsfeed')implementation project(':cpt_ewallet')implementation project(':cpt_im')implementation project(':cpt_profile')
}


这样就很方便的管理Gradle版本,配置等信息,一旦有修改也不至于全部的模块的gradle文件都要改。

我们再基类的gradle配置中指定了版本,那么全部的模块都是使用统一的版本,再配合引入库的时候exclude的操作,完全不用担心引入多个版本导致兼容性的问题。

版本管理源码在此,最后感谢完结了。

作者:newki
链接:https://juejin.cn/post/7098878694449479688
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


推荐阅读
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 本文详细介绍了GetModuleFileName函数的用法,该函数可以用于获取当前模块所在的路径,方便进行文件操作和读取配置信息。文章通过示例代码和详细的解释,帮助读者理解和使用该函数。同时,还提供了相关的API函数声明和说明。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • imx6ull开发板驱动MT7601U无线网卡的方法和步骤详解
    本文详细介绍了在imx6ull开发板上驱动MT7601U无线网卡的方法和步骤。首先介绍了开发环境和硬件平台,然后说明了MT7601U驱动已经集成在linux内核的linux-4.x.x/drivers/net/wireless/mediatek/mt7601u文件中。接着介绍了移植mt7601u驱动的过程,包括编译内核和配置设备驱动。最后,列举了关键词和相关信息供读者参考。 ... [详细]
  • 本文介绍了Android 7的学习笔记总结,包括最新的移动架构视频、大厂安卓面试真题和项目实战源码讲义。同时还分享了开源的完整内容,并提醒读者在使用FileProvider适配时要注意不同模块的AndroidManfiest.xml中配置的xml文件名必须不同,否则会出现问题。 ... [详细]
author-avatar
湘西有堵墙
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有