2024年Android老油条都知道的7个Gradle实用奇技淫巧,android面试app

尾声

如果你想成为一个优秀的 Android 开发人员,请集中精力,对基础和重要的事情做深度研究。

对于很多初中级Android工程师而言,想要提升技能,往往是自己摸索成长,不成体系的学习效果低效漫长且无助。 整理的这些架构技术希望对Android开发的朋友们有所参考以及少走弯路,本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。

这里,笔者分享一份从架构哲学的层面来剖析的视频及资料给大家梳理了多年的架构经验,筹备近6个月最新录制的,相信这份视频能给你带来不一样的启发、收获。

Android进阶学习资料库

一共十个专题,包括了Android进阶所有学习资料,Android进阶视频,Flutter,java基础,kotlin,NDK模块,计算机网络,数据结构与算法,微信小程序,面试题解析,framework源码!

大厂面试真题

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

《2019-2021字节跳动Android面试历年真题解析》

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

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

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

1.后续添加依赖不需要改动build.gradle,直接在config.gradle中添加即可

2.精简了build.gradle的长度

3.支持代码提示的Gradle依赖管理


上面介绍了通过config.gradle管理依赖的方法

在我们添加Gradle依赖时,还有一些痛点

1.不支持代码提示

2.不支持单击跳转

3.多模块开发时,不同模块相同的依赖需要复制粘贴

使用buildSrc+kotlin可以解决这个问题

效果如下:

由于buildSrc是对全局的所有module的配置,所以可以在所有module中直接使用

buildSrc vs includeBuild

上面介绍的方法使用的是buildSrc,使用起来比较方便

不过它的缺点在于构建速度上会慢一些,使用includeBuild可以实现同样的效果

两者实现的最终效果是差不多的

4.Gradle模块化


我们在开发中,引入一些插件时,有时需要在build.gradle中引入一些配置,比如greendao,推送,tinker

这些其实是可以封装在相应gradle文件中,然后通过apply from引入

举个例子,例如在我们使用greendao数据库时,需要在build.gradle中指定版本

这种时候应该新建一个greendao-config.gradle

apply plugin: ‘org.greenrobot.greendao’

//greenDao指定版本和路劲等

greendao {

//数据库的schema版本,也可以理解为数据库版本号

schemaVersion 1

//设置DaoMaster、DaoSession、Dao包名,也就是要放置这些类的包的全路径。

daoPackage ‘com.example.ausu.big_progect.dao’

//设置DaoMaster、DaoSession、Dao目录

targetGenDir ‘src/main/java’

}

复制代码

然后再在build.gradle中引入

apply from ‘greendao-config.gradle’

复制代码

这样做主要有2个优点

1.单一职责原则,将greendao的相关配置封装在一个文件里,不与其他文件混淆

2.精简了build.gradle的代码,同时后续修改数据库相关时不需要修改build.gradle的代码

5.Library模块Gradle代码复用


随着我们项目的越来越大,Library Module也越建越多,每个Module都有自己的build.gradle

但其实每个build.gradle的内容都差不多,我们能不能将重复的部分封装起来复用?

我们可以做一个 basic 抽取,同样将共有参数/信息提取到 basic.gradle 中,每个 module apply,这样就是减少了不少代码量

apply plugin: ‘com.android.library’

apply plugin: ‘kotlin-android’

apply plugin: ‘kotlin-android-extensions’

apply plugin: ‘kotlin-kapt’

android {

// 指定用于编译项目的 API 级别

compileSdkVersion Versions.compileSDK

// 指定在生成项目时要使用的 SDK 工具的版本,Android Studio 3.0 后不需要手动配置。

buildToolsVersion Versions.buildTools

// 指定 Android 插件适用于所有构建版本的版本属性的默认值

defaultConfig {

minSdkVersion Versions.minSDK

targetSdkVersion Versions.targetSDK

versionCode 1

versionName “1.0”

}

// 配置 Java 编译(编码格式、编译级别、生成字节码版本)

compileOptions {

encoding = ‘utf-8’

sourceCompatibility JavaVersion.VERSION_1_8

targetCompatibility JavaVersion.VERSION_1_8

}

kotlinOptions {

jvmTarget = JavaVersion.VERSION_1_8.toString()

}

lintOptions {

// lint 异常后继续执行

abortOnError false

}

}

dependencies {

implementation fileTree(dir: ‘libs’, include: [‘*.jar’])

}

复制代码

然后在相应的模块的build.gradle中引入即可

apply from:“…/basic.gradle”

dependencies {

api Deps.constraintLayout

api Deps.retrofit

}

复制代码

这样是不是简洁很多?读者可根据项目实际情况判断是否适合抽取basic.gradle使用

6.资源文件分包


随着项目越来越大,项目中的资源文件也越来越大,比如layoutdrawable文件夹下的文件数量常常可达几百甚至上千个

我们能不能像代码一样,对资源文件进行分包呢?

答案是可以的,主要是利用gradlesourceSets属性

我们可以将资源文件像代码一样按业务分包,具体操作如下

1.新建res_xxx目录 [图片上传失败…(image-ce47f9-1617970032040)]

main 目录下新建 res_core, res_feed(根据业务模块命名)等目录,在res_core中新建res目录中相同的文件夹如:layoutdrawable-xxhdpivalues等。

2.在gradle中配置res_xx目录

android {

//…

sourceSets {

main {

res.srcDirs(

‘src/main/res’,

‘src/main/res_core’,

‘src/main/res_feed’,

)

}

}

}

复制代码

以上就完成了资源文件分包,这样做主要有几点好处

1.按业务分包查找方便,结构清晰

2.strings.xmlkey-value型文件多人修改可以减少冲突

3.当删除模块或做组件化改造时资源文件删除或迁移方便,不必像以前一样一个个去找

7.AAR依赖与源码依赖快速切换


当我们的项目中Module越来越多,为了加快编译速度,常常把Module发布成AAR,然后在项目中直接依赖AAR

但是我们有时候又需要修改AAR,就需要依赖于源码

所以我们需要一个可以快速地切换依赖AAR与依赖源码的方式

我们下面举个例子,以retrofit为例

假如我们要修改retrofit的源码,修改步骤如下:

1.首先下载retrofit,可以放到和项目同级的目录,并修改目录名为retrofit-source,以便区分

2.在settings.gradle文件中添加需要修改的aar库的源码project

include ‘:retrofit-source’

project(‘:retrofit-source’).projectDir = new File(“…/retrofit-source”)

复制代码

3.替换aar为源码

build.gradle(android) 脚本中添加替换策略

allprojects {

repositories {

}

configurations.all {

resolutionStrategy {

dependencySubstitution {

substitute module( “com.squareup.retrofit2:retrofit”) with project(‘:retofit-source’)

}

}

}

}

复制代码

如上几步,就可以比较方便地实现aar依赖与源码依赖间的互换了

这样做的主要优点在于

1.不需要修改原有的依赖配置,而是通过全局的配置,利用本地的源码替换掉aar,侵入性低

2.如果有多个Module依赖于同一个aar,不需要重复修改,只需在根目录build.gradle中修改一处

文末

架构师不是天生的,是在项目中磨练起来的,所以,我们学了技术就需要结合项目进行实战训练,那么在Android里面最常用的架构无外乎 MVC,MVP,MVVM,但是这些思想如果和模块化,层次化,组件化混和在一起,那就不是一件那么简单的事了,我们需要一个真正身经百战的架构师才能讲解透彻其中蕴含的深理。

移动架构师

系统学习技术大纲

一线互联网Android面试题总结含详解(初级到高级专题)

image

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

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

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

和在一起,那就不是一件那么简单的事了,我们需要一个真正身经百战的架构师才能讲解透彻其中蕴含的深理。

[外链图片转存中…(img-P1ap0hPD-1715685676609)]

[外链图片转存中…(img-HseDhj6s-1715685676612)]

一线互联网Android面试题总结含详解(初级到高级专题)

[外链图片转存中…(img-r9I9bIm2-1715685676612)]

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

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

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

  • 21
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值