美文网首页
破解遗留系统快速重构的5步心法(附实例)

破解遗留系统快速重构的5步心法(附实例)

作者: 黄俊彬 | 来源:发表于2023-02-19 17:04 被阅读0次

前两天和一个架构师朋友闲聊,说到了 「重构」 这个话题,他们公司早年间上线的项目系统,因一直没专人在演进过程中为代码质量负责,导致现在代码越来越混乱,逐渐堆积成“屎山”,目前的维护成本已远高于重新开发一套新系统,想重构也没有合适的人力物力以及时机,只能继续凑合用。说实在的,这确实不只是朋友他们一家公司会遇到的问题,而造成这种情况的原因大概率有以下几点:

  • 编码之前缺乏有效的设计
  • 成本上的考虑,在原功能堆砌式编程
  • 缺乏有效代码质量监督机制

可以看出,最好的解决办法就是不要堆积遗留问题。对此,业界现有的比较“成熟”的解决思路是:通过持续不断地重构将代码中的“坏味道”清除掉。 可惜说起来容易,做起来却很难,要克服遗留系统重构往往有三大阻力:首要的就是怕出错,不知道怎样保障重构的安全性和效率,其次,很多遗留系统规模及业务复杂度太高 开发人员又缺乏改造的方法及经验,根本不知从何入手 而且如果修改只是单单停留在代码层面上,很难彻底解决问题,从而提高研发效率和提高产品质量。 后来我们扒了不少文章,终于看到一个不错的,一针见血地指出了三个关键点:自动化、系统化及工程化 简单来讲,就是要先通过自动化重构提高开发效率,再通过系统的流程方法,逐一击破,最后通过工程化管理,持续演进,如下图所示。

图片

分享人是 Thoughtworks 资深咨询师、也是中国区 DTO 团队敏捷技术教练「黄俊彬」。最近极客时间还特意邀请他做了一个重构系统专栏—— 大型 Android 系统重构实战》 ,提前看了下导读,里面不但有详细的关于遗留系统重构三大关键的指南讲解,他还特意选择了一个在 实际工作可能会遇到的 App 项目,直接带你实操改造,这点还挺难得的。

在这个过程中,他自己也总结了一套行之有效和高效实战系统重构的方法论,并且尝试把这套方法论传授给更多的人,所以,他跟极客时间合作推出了 《大型 Android 系统重构实战》 专栏。这种资历的大佬能出来开课,把自己独特的方法和经验共享出来,真的很难得。五步提升,带你真正实战系统重构 。

为了让内容能够切切实实地帮助到大家,听说这个专栏经过了多次深入用户、专家调研的反复打磨。而且实打实地带大家实战,围绕着一个贴近日常开发场景的 APP 项目重构。特意看了下,这个实例里综合了很多遗留系统里的典型代码“坏味道”和代码耦合问题。 完整跟下来,不但能帮助你和你的团队掌握专栏里的流程方法、工具、设计思想,还能融会贯通到其他项目中,真正做到提高团队效率,提升最终的交付质量。 图片

第一步:基础提升篇本篇主要讲解重构以及自动化测试的基础知识,包括重构的类型、时机、安全重构的手法,自动化测试的策略和常用框架。这部分内容是日常开发的必备技能,能有效帮助你提高编码的效率以及代码的质量。

第二步:分析设计篇这部分是针对遗留系统业务复杂度高的问题,会结合实例教你如何分析系统、诊断问题。根据现有架构与理想架构设计的差距,找出撬动遗留系统的关键杠杆点。学完这个部分,你就能了解主流的应用架构,掌握常用的遗留系统分析工具

第三步:解耦重构篇通过系统的重构方法流程,借助自动化测试以及自动化重构方法,带你对示例项目做组件化重构和组件内的分层架构重构。另外,黄老师还会给你讲解业内一些主流的注入及路由框架使用及原理,帮助你在项目中用好这些框架。学完这个部分,重构易出错的问题就能迎刃而解了。

第四步:持续交付篇这一篇会系统介绍组件化后项目的版本管理、制品管理以及分层分级流水线的设计等工程管理问题。这些实用技巧是老师从多年的项目经验中沉淀总结而来,有助于解决改造不全面的问题。

第五步:扩展篇这一部分会将遗留系统的问题从 APP 扩展到整个手机厂商的 Android 定制系统,带你了解Android定制系统的耦合问题以及解耦的策略及方法。这个部分,可以扩展你的知识面,让你站在更复杂的问题域上,综合运用之前所学的内容,以不变应万变。 说了这么多,具体内容我们可以看看一起目录。

图片

详细可直接查看《大型Android系统重构实战》

相关文章

  • 移动应用遗留系统重构-MVP重构示例篇

    移动应用遗留系统重构(13)-???一镜到底!MVP重构示例篇 前言 上一篇移动应用遗留系统重构(12)- 编译调...

  • 当重构遇到糟糕的物理设计

    --- 导语 糟糕的物理设计是对遗留大型系统中进行重构的非常棘手的一个问题,本文相机阐述了遗留系统中存在哪些糟糕的...

  • iOS代码重构

    遗留代码重构的原因: 风险: 详情链接:浅谈遗留代码的重构 从以下几个方面谈谈重构 1. 整理资源文件 删除未使用...

  • “领域驱动设计”答疑

    过去一年主要在大型嵌入式系统中进行软件重构的咨询工作。对于大规模的遗留系统重构,一方面会借助领域建模帮助深入了解业...

  • 如何深度重构UIViewController实例-直播界面

    如何深度重构UIViewController实例-直播界面 如何深度重构UIViewController实例-直播界面

  • #千日千文#【51/1000】系统思考之道

    一、前言 通过这篇文章分析,你会得到如何破解商业系统困境的几种心法。推荐阅读书籍《系统之美》(《Thinking ...

  • 浅谈遗留代码的重构

    背景 《重构》诞生至今有近17个年头了,日常开发中大家谈到重构,要么非常随意,认为重构就是改代码;要么非常谨慎,把...

  • 浅谈遗留代码的重构

    背景 《重构》诞生至今有近17个年头了,日常开发中大家谈到重构,要么非常随意,认为重构就是改代码;要么非常谨慎,把...

  • Spring boot性能优化

    笔者刚入职新公司领导让针对api项目进行重构,由于当前系统用play框架写的加上历史遗留原因,造成当前的a...

  • 重构并没有你想象的那么简单

    本文转载自 下次老板让你重构系统,让他看看这篇文章 面对遗留的老系统,人人都很不爽,都想推倒重来。但是要如何推倒重...

网友评论

      本文标题:破解遗留系统快速重构的5步心法(附实例)

      本文链接:https://www.haomeiwen.com/subject/fkoikdtx.html