这个演变非常像后台应用的单体架构到微服务架构的演变,适用于公司内部有多个产品需要同时迭代的场景。随着单体应用向多Module的演变,原先的各个组件都独立到不同的Module中去了。
大概有两个阶段:
-
单一入口Module + 公共类库Module
-
多入口Module + 多公共业务Module + 公共类库Module
第一个阶段很好理解,也是一个自然而然的演变。因为项目中很多公共的模块,比如日志模块,网络模块,数据模块。这些模块与逻辑无关,可以给任何项目使用,所以单独开一个Module或者传到maven库。如果要开发新的项目,那也只是将公共类库Module移植过去即可。
所以,第一阶段的项目Module结构大概是这样:
-
App Module,负责提供项目入口,完成各个业务逻辑功能
-
Library Module,负责提供项目公共组件,比如日志组件,网络组件,存储组件
-
其他三方库Module
以抖音App为例:
上面的阶段能做到功能模块的重用,但是没有涉及到业务逻辑的重用。新项目也有登录注册功能,难道要重新写一遍么?
你可能担心两个项目的登录注册逻辑能一样么,界面也不可能一样啊。界面肯定是不一样的,但是登录注册逻辑大部分是一样的。这就说明我们其实可以对一些公共业务划分Module,对于不一样的地方,完全可以动态化。但是公共业务不能划入类库Module中,因为通用性不够;还要注意业务Module的抽离本着只抽业务,不抽UI的原则。
当业务Module和类库Module抽离之后,不同的项目我们可以添加不同的入口Module,入口Module更多是完成入口功能,和UI定制化功能,以及完成一部分差异化的实在不能共用的业务逻辑。
所以,第二阶段的项目Module结构大概是这样:
-
App1 Module,负责提供App1的入口,完成App1的所有UI逻辑和部分不能共用的业务逻辑
-
App2 Module,负责提供App2的入口,完成App1的所有UI逻辑和部分不能共用的业务逻辑
-
Login Module,负责提供登录注册功能
-
Video Module,负责提供视频相关功能
-
Library Module,负责提供公共模块功能
-
其他三方Module
客户端开发中,UI的变数最大,上面的Module划分尽量将变化少的东西复用,将变化大的东西剥离出来。
他们之间的调用关系应该符合这样的规则:
-
App入口Module可以调用业务Module和Library Module;
-
业务Module可以调用Library Module,业务Module之间不能相互调用,也但不能调用App入口Module,目的是保持单向调用流程
-
Library Module只能被调用。
以抖音App为例:
如果你发现业务Module需要调用App入口Module,或者其他情况,可能你的Module架构设计有问题。
[](
)Module间通信
其实上面的架构不存在Module之间的通信,也不需要。
假设这样一个场景: 在App1中的登录界面,调用的Login模块的登录逻辑,登录完成后需要跳转用户信息界面。
上面的场景只需直接调用Login模块的逻辑即可,即便发生了不同UI跳转,也不需要Module通信,因为所有的UI都写在App1中了。
如果当初将登录相关的UI也抽到Login模块中,看起来封装度更高,其实有很多不方便。在上面的场景中,需要从Login模块的UI调用其他模块的UI,这样调用流程变得复杂,而且必须要ARouter这样的通信工具;问题是Login的UI在各个App中不太可能一样,如果一样,那么则可以抽进去。
[](
)插件化和热修复
很多大厂的App功能实在是太多,如果一开始就将所有功能都纳入App中,体积下不来,问题是有一些功能很多人从来也不用。
最后
希望本文对你有所启发,有任何面试上的建议也欢迎留言分享给大家。
好了,今天的分享就到这里,如果你对在面试中遇到的问题,或者刚毕业及工作几年迷茫不知道该如何准备面试并突破现状提升自己,对于自己的未来还不够了解不知道给如何规划,来看看同行们都是如何突破现状,怎么学习的,来吸收他们的面试以及工作经验完善自己的之后的面试计划及职业规划。
**[CodeChina开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》](
)**
好了~如果你看到了这里,觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言。一定会认真查询,修正不足。谢谢。
为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!
本文已被腾讯CODING开源托管项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》收录,自学资源及系列文章持续更新中…
后还会更新技术干货,谢谢您的支持!
本文已被腾讯CODING开源托管项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》收录,自学资源及系列文章持续更新中…