来自一位阿里朋友的组件化架构实践
Android 从 2008 年 10 月发布至今已经第 13 个年头了,开发者们从 Android 1.0 的版本跨越到了 Android 11,马上也将迎来 Android 12 的到来……在这个过程中,我们经历了很多。
对于如何去衡量一个开发者的水平到底有多高,一般面试官会看他会什么,能干什么。
如果是一个刚入行的新手,公司对他的要求就不会太高。
但是在 Android 行业有太多 3-5 年工作经验的“新手”。他们一般如何开发的呢,项目架构毫无章法,代码毫无设计模式,性能体验毫无快感。
所以我们会发现水平的高与低,完全可以用代码的好与坏来衡量。对于开发者来说,写好代码的第一步就是选择好的架构设计。
现在 Android 行业中最受欢迎的架构模式就是组件化开发了。为什么呢?
1.在大厂的项目中,组件化都是必备的。
2.对于团队开发来说,组件化也是必备的。
3.对于初级进阶中高级的开发者来说,组件化也是必备的。
4.对于大项目的维护角度来说,组件化还是必备的。
5.对于提升开发效率来说,组件化依然是必备的。
传统 APP 架构图
传统 APP 架构图
如图所示:
普遍使用的 Android APP 技术架构,往往是在一个界面中存在大量的业务逻辑,而业务逻辑中充斥着各种网络请求、数据操作等行为,整个项目中也没有模块的概念,只有简单的以业务逻辑划分的文件夹,并且业务之间也是直接相互调用、高度耦合在一起的。单一工程模型下的业务关系,总的来说就是:你中有我,我中有你,相互依赖,无法分离。如下图:
架构设计图
组件化架构图
业务组件之间是独立的,互相没有关联,这些业务组件在集成模式下是一个个 Library,被 APP 壳工程所依赖,组成一个具有完整业务功能的 APP 应用,但是在组件开发模式下,业务组件又变成了一个个 Application,它们可以独立开发和调试,由于在组件开发模式下,业务组件们的代码量相比于完整的项目差了很远,因此在运行时可以显著减少编译时间。
但是问题就来了,很多开发人员以前根本就没有接触过组件化开发,那么我们应该怎样去掌握这个技术呢?
小编精心整理了前阿里 P7 移动架构师 Zero 老师的《高级 Android 组件化强化实战(附源码)》资料,带大家一步一步手写阿里 ARouter 组件化路由框架,掌握组件化开发,让你能够真正的把组件化运用到自己的项目中去。(文末免费领取)
附源码)》
一、 Android 组件化初识
组件化
插件化
业务逻辑层
组件化开发所遇问题
二、Android 组件化初探
组件化演示案例
WanAndroid APP 组件化项目实战附 demo
评论