移动应用遗留系统重构(4)-分析篇

  • 公用业务能力复用,有一层专门统一管理应用的业务通用组件,如分享、推送、登录等
  1. 低耦合
  • 业务模块间通过API方式依赖,不依赖具体的模块实现
  • 依赖方向清晰,上层模块依赖下层模块
  1. 并行研发
  • 业务模块支持独立编译调试
  • 业务模块独立发布

结合该4层架构、已有的代码,以及业务的后续演化,团队设计的新架构如下

分析工具

ArchUnit

有了架构设计后,我们就能识别代码的边界,这里我们可以通过Archunit进行边界约束描述。我们可以得到2条通用的守护规则。

  1. 垂直方向,下层模块不能反向依赖上层
  2. 横向方向,组件之间不能存在相互的依赖

转化为ArchUnit的测试用例如下:

@ArchTest
public static final ArchRule architecture_layer_should_has_right_dependency =layeredArchitecture()
.layer(“Library”).definedBy(“…cloud.disk.library…”)
.layer(“PlatForm”).definedBy(“…cloud.disk.platform…”)
.layer(“FileBundle”).definedBy(“…cloud.disk.bundle.file…”)
.layer(“DynamicBundle”).definedBy(“…cloud.disk.bundle.dynamic…”)
.layer(“UserBundle”).definedBy(“…cloud.disk.bundle.user…”)
.layer(“AllBundle”).definedBy(“…cloud.disk.bundle…”)
.layer(“App”).definedBy(“…cloud.disk.app…”)
.whereLayer(“App”).mayOnlyBeAccessedByLayers()
.whereLayer(“FileBundle”).mayOnlyBeAccessedByLayers(“App”)
.whereLayer(“DynamicBundle”).mayOnlyBeAccessedByLayers(“App”)
.whereLayer(“UserBundle”).mayOnlyBeAccessedByLayers(“App”)
.whereLayer(“PlatForm”).mayOnlyBeAccessedByLayers(“App”,“AllBundle”)
.whereLayer(“Library”).mayOnlyBeAccessedByLayers(“App”,“AllBundle”,“PlatForm”);

当然这个用例的执行是失败的,因为我们基本的包结构还没有调整。但有了架构守护测试用例,我们就可以逐步把代码移动到对应的Package中,直到守护用例运行通过为止。

接下来我们先运用IDE工具进行基础的包结构调整,调整后的结构如下

调整后运行ArchUnit测试运行结果如下

这些异常的提示就是我们需要处理的异常依赖。但是ArchUnit的这个提示比较不不友好,接下来我们介绍另外一种分析异常依赖的方式,使用Intellij Dependencies 。

Intellij Dependencies

我们选择对应的Package,选择Analyze菜单,点击Dependencies,可以找出该Package所依赖的相关类。

我们选择dynamic Package进行分析后,发现根据现有的架构约束,存在横向的Bundle依赖需要进行解除依赖。

我是在实际重构过程中,我们可以频繁借助该功能验证耦合解除情况,并且同时通过ArchUnit测试做好守护。

详细代码见Cloud Disk

总结

这一篇我们分享了如何借助工具进行异常依赖的分析。当我们有了未来的架构设计后,可以借助ArchUnit进行架构测试守护,通过Intellij的Dependendencies 我们可以方便以Package或者Class为单位进行依赖分析。

当我们已经分析出需要处理的异常依赖,接下来我们就可以逐步进行重构。下一篇,我们将给大家分享实践总结的一些重构套路,移动应用遗留系统重构(5)- 重构方法篇。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

下图是我进阶学习所积累的历年腾讯、头条、阿里、美团、字节跳动等公司2019-2021年的高频面试题,博主还把这些技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节

整理不易,望各位看官老爷点个关注转发,谢谢!祝大家都能得到自己心仪工作。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

都能得到自己心仪工作。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值