组件化作为Android客户端技术的一个重要分支,近年来一直是业界积极探索和实践的方向。每个大厂内部的各个Android开发团队也在尝试和实践不同的组件化方案,并且在组件化通信框架上也有很多高质量的产出。本文主要介绍我们的组件化方案,希望对从事Android组件化开发的同学能有所启发。
近年来,为什么这么多团队要进行组件化实践呢?组件化究竟能给我们的工程、代码带来什么好处?我们认为组件化能够带来两个最大的好处:
1.提高组件复用性
可能有些人会觉得,提高复用性很简单,直接把需要复用的代码做成Android Module,打包AAR并上传代码仓库,那么这部分功能就能被方便地引入和使用。但是我们觉得仅仅这样是不够的,上传仓库的AAR库是否方便被复用,需要组件化的规则来约束,这样才能提高复用的便捷性。
2.降低组件间的耦合
我们需要通过组件化的规则把代码拆分成不同的模块,模块要做到高内聚、低耦合。模块间也不能直接调用,这需要组件化通信框架的支持。降低了组件间的耦合性可以带来两点直接的好处:第一,代码更便于维护;第二,降低了模块的Bug率。
要实现组件化需要考虑的问题主要包括下面几个:
代码解耦。将一个庞大的工程拆分解耦,这是非常耗时耗力的工作,但这也是最基础最重要的一步数据传递。每个组件都有可能提供给其他组件使用,主项目与组件、组件与组件之间的数据传递UI跳转。组件的生命周期。组件加载、卸载和降维的生命周期集成调试。在开发阶段如何做到按需的编译组件?一次调试中可能只有一两个组件参与集成,这样编译的时间就会大大降低,提高开发效率。代码隔离。如何杜绝耦合的产生。
1.组件化和模块化的区别
组件化和插件化的区别组件化开发的优势业务逻辑层
5.从组件化实战来解决问题
Android组件化基础
1.组件化演示案例
模块化和组件化模块化组件化组件化Demo项目分析组件application和library动态切换组件间的数据传递和方法调用组件类(例如:Fragment)的获取,以及夸组件页面跳转和通讯
2. WanAndroid APP 组件化项目实战附demo
简介版本更新效果图主要功能项目目录结构主要开源框架
1.从智行 Android 项目看组件化架构实践
前言概述组件化调整的原因和目标组件化架构调整的整体规划组件化架构调整中遇到的一些问题组件化架构的实践成果
2.得到 App
Android彻底组件化demo发布JIMU使用指南组件化拆分的感悟Android彻底组件化—代码和资源隔离代码隔离资源隔离调试切换
组件化:代码隔离也难不倒组件的按序初始化
问题的根源为什么不使用官方StartUp而选择造轮子设计思路有向无环图(DAG)环校验契合需求的排序方式任务的描述在JIMU中使用重要事项
3.微信 App
微信Android模块化架构重构实践微信Android架构历史为何再次重构微信重塑模块化取舍和选择代码之外,架构之内
4.蘑菇街 App
蘑菇街 App 的组件化之路实现方式组件生命周期管理壳工程遇到的问题持续集成周边设施小结
蘑菇街 App 的组件化之路·续
统一的调用实现通过 Category 来统一组件对外暴露的接口更明确的表述注册这个组件关心的 URL注册这个组件能够被调用的方法/属性在 App 生命周期的不同阶段做不同的响应针对casatwy的一些回应小结
5 爱奇艺 App
关于组件化基于Service的IPC通信组件化跨进程通信的核心诉求Andromeda架构分析
6.美团 App
外卖客户端容器化架构的演进背景美团外卖业务介绍美团外卖移动端历史架构概述
美团外卖容器化架构全景图
什么是容器化架构容器化架构的优势外卖容器化架构全景图容器化的挑战外卖跨端容器建设MRN容器Titans容器
外卖页面容器建设
页面容器化设计思路业务构建模块标准化小结
外卖容器化架构的衡量指标
容器化架构衡量指标的特点链路指标关键指标外卖容器化架构的监控运维外卖容器化架构的发布能力容器化架构发布体系跟版本发布流程bundle资源发布多种发布能力综合使用
7. 美团Android组件化方案及组件消息总线modular-event实战
背景组件化之前的状态组件化方案调研美团其他团队组件化方案调研组件化方案组件化消息总线框架modular-event组件消息总线modular-event的实现消息总线modular-event的结构使用动态代理实现运行时调用订阅和发送的模式
8. 美团Android消息总线的演进之路:用LiveDataBus替代RxBus、EventBus
背景发布/订阅模式RxBus的出现引入LiveDataBus的想法为什么使用LiveData构建数据通信总线LiveDataBusLiveDataBus的设计和架构LiveDataBus最终实现
9.WMRouter:美团外卖Android开源路由框架
10.美团猫眼android模块化实战-可能是最详细的模块化实战
11.携程App(篇幅过长,无法展示全部)
12.支付宝 App
……
总结:组件化后让代码结构非常清晰,分层结构以及之间的交互很明了,团队中的任何一个人都可以很轻松的绘制出代码结构图,这个在之前是没法做到的,并且每个组件的编译时间从 10 分钟降到了几十秒,工作效率有了很大地提升,最关键的还是解耦之后,每次开发需求的时候,面对的代码越来越少,不用背负那么重的代码包袱,可以说达到了“代码越写越少”的理想情况。如果你是一位Android开发者学好组件化是非常有必要的,而深入理解组件化的实战更是重中之重。