2024年安卓最新Android开发中依赖库的版本管理_安卓原生怎么改改依赖库的版本,移动端h5页面开发工具

文末

当你打算跳槽的时候,应该把“跳槽成功后,我能学到什么东西?对我的未来发展有什么好处”放在第一位。这些东西才是真正引导你的关键。在跳槽之前尽量“物尽其用”,把手头上的工作做好,最好是完成了某个项目或是得到提升之后再走。跳槽不是目的,而是为了达到最终职业目标的手段

最后祝大家工作升职加薪,面试拿到心仪Offer


网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

//IM正式环境
public static final int TIMSDK_APPID = 987654321;

//推送的正式环境
//推送的测试环境
//Web的正式环境  等等

}


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


**config.gradle:**



ext {

// isLocalRelease = true //本地打包环境 release设置true
isLocalRelease = false //本地打包环境 debug设置false

// isReleaseUrl = true //使用的服务器域名的环境, 正式环境设置true
isReleaseUrl = false //使用的服务器域名的环境,测试环境设置false (线上环境)

// 测试环境的域名
baseUrl_dev = 'http://baidu-api-dev.guabean.com'
// 正式环境的域名
baseUrl_relese = 'https://api.baidu.com'

//极光测试环境key
jpush_key_dev = '12345678'
//极光正式环境key
jpush_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_relese
        buildConfigField 'String', 'Base_Url', "\"${baseUrlRelese}\""

    } else {
        String baseUrlDev = rootProject.ext.baseUrl_dev
        buildConfigField '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依赖不同的库,导致各个版本不同,容易导致不兼容的问题。


![](https://img-blog.csdnimg.cn/809ebe10d79b462bb21436743b5ba907.png)


如图,我们封装了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.compileSdk

defaultConfig {
    minSdk versions.minSdk
    targetSdk versions.targetSdk

    versionCode 1
    versionName "1.0"

    testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    consumerProguardFiles 'consumer-rules.pro'

    multiDexEnabled true
    vectorDrawables.useSupportLibrary = true

    javaCompileOptions {  //Hilt的编译配置
        annotationProcessorOptions {
            arguments += ["foo" : "bar"]
        }
    }
}

buildTypes {
    release {
        minifyEnabled false
        multiDexKeepProguard file('multidex-config.pro')
        proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
    }
    debug {
        multiDexKeepProguard file('multidex-config.pro')
    }
}

compileOptions {
    sourceCompatibility JavaVersion.VERSION_1_8
    targetCompatibility JavaVersion.VERSION_1_8
}

kotlinOptions {
    freeCompilerArgs = ['-Xjvm-default=enable']
    jvmTarget = JavaVersion.VERSION_1_8
    useIR = 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’])

//每个模块都要实现的依赖
//Test
testImplementation deps.android.junit
androidTestImplementation deps.android.test_junit
androidTestImplementation deps.android.test_espresso
//依赖注入
implementation deps.support.hilt
kapt 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.appcompat
api 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 = true
viewBinding = 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 100
versionName “1.0.0”
applicationId “com.hongyegroup.running”
}

buildFeatures {
    dataBinding = true
    viewBinding = true
}

}

dependencies {

//依赖注入
implementation deps.support.hilt
kapt deps.support.hilt_kapt

implementation project(':cs_cptServices')  //运行模块默认添加Service模块的

}


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



apply from: “…/runing_default_config.gradle”

android {
defaultConfig {
versionCode 100
versionName “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的操作,完全不用担心引入多个版本导致兼容性的问题。


后面有机会讲一下组件化项目。  
 版本管理[源码]( )在此,最后感谢完结了。


![请添加图片描述](https://img-blog.csdnimg.cn/3c2e96748bf3414c897778272f471972.png)



> 
> 作者:newki  
>  链接:https://juejin.cn/post/7098878694449479688
> 
> 
> 



### 最后

跳槽季整理面试题已经成了我多年的习惯!**在这里我和身边一些朋友特意整理了一份快速进阶为Android高级工程师的系统且全面的学习资料。涵盖了Android初级——Android高级架构师进阶必备的一些学习技能。**

附上:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

![](https://img-blog.csdnimg.cn/img_convert/5a09a76e6387811fcab9b59c786361bf.webp?x-oss-process=image/format,png)




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618156601)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)

[外链图片转存中...(img-X9BB8Jea-1715808546493)]




**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化学习资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618156601)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值