移动应用遗留系统重构(5)- 重构方法篇

| — | — |
| 下沉 | 原本类功能属于Library或者Platform的,直接下沉。例如LogUtil 或 DateUtil等 |
| 接口提取 | 适用于Bundle间有数据或者行为依赖。例如某个BundleA中的classA需要触发BundleB的某个业务行为 |
| 路由跳转 | 适用于UI页面间跳转。例如某个BundleA中的Activity1,需要跳转到BundleB的Activity2 |

重构手法:

  1. 类下沉
  • 具体类移动到适当的 Lib 模块中

  • 在调用模块增加对该 Lib 的依赖

  1. 接口提取
  • 在适当的公用模块中创建空的接口
  • 将调用具体页面类的跳转代码块所在的包中建立新的实现类实现该接口
  • (自动)将调用代码块通过 Extract method 提取成新方法

如已经是独立方法跳过此步

  • (自动)在原调用逻辑所属的类中增加实现类成员变量作为delegate

需要预留 Inject 接口,建议采用 Constructor Inject,静态成员提供setter

  • (自动)将新方法调用转移到delegate

如果是静态方法先通过 Change Method Signature 将 delegate 作为参数传给该方法

  • (自动)将新方法 Pull up 到接口
  • (自动)将实现类移动到壳程序中
  • 在壳程序中实现实现类的Inject
  1. 路由跳转
  • 在跳转类定义对应的映射Path
  • 在调用处使用对应的path进行跳转

3.移动代码及资源

当包的异常依赖全部解耦完后,就可以直接进行移动了。这里我们分享2中常用的代码移动方式。

  1. Move

这种方式大家应该比较常用,选择一个File或者Directory,按下F6选择希望移动后的目录则可。

但是这种方式会存在一个问题,就是被移动的类如果依赖了其他的类或者资源,移动后会出现依赖异常。

适用场景:移动的File或Directory没有其他的依赖

  1. Modularize

Modularize能够分析出移动的File存在的相关依赖,并一起关联移动,很好解决Move的痛点,非常适用于跨Module的移动。

选择移动的Module后点击Preview。

这里注意,有一些划线的文件,那是因为这个文件同时被多处引用,如果跟随一起移动,那么其他的地方会报错。所以我们需要将划线的文件先移动至公用的合适位置。待Preview没有任何的文件划线时,就可以进行移动。

4.包解耦验收

  • 所有模块编译通过
  • 所有新增模块符合模块依赖规则
  • 通过架构守护测试

总结

这一篇我们分享了进行依赖解除的重构流程,主要为4个操作步骤,识别内聚包、解除依赖、移动、验收。同时也介绍了Intellij中非常好用的Modularize功能。接下来我们就可以开始动手进行代码重构,但此时我们又面临着另外一个问题,也是很多同学在做重构时经常担心的一个问题。重构时如何保证功能的正确性,不会修改出新问题。

下一篇移动应用遗留系统重构(6)- 测试篇,我们将分享对于单体移动应用遗留系统,如何制定测试策略及有效补充自动化测试,更好为重构保驾护航。

系列链接

移动应用遗留系统重构(1)- 开篇

移动应用遗留系统重构(2)-架构篇

移动应用遗留系统重构(3)-示例篇
移动应用遗留系统重构(4)-分析篇
大纲


关于

尾声

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

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

最后想要拿高薪实现技术提升薪水得到质的飞跃。最快捷的方式,就是有人可以带着你一起分析,这样学习起来最为高效,所以为了大家能够顺利进阶中高级、架构师,我特地为大家准备了一套高手学习的源码和框架视频等精品Android架构师教程,保证你学了以后保证薪资上升一个台阶。

当你有了学习线路,学习哪些内容,也知道以后的路怎么走了,理论看多了总要实践的。

进阶学习视频

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

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

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

  • 29
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值