代码重构的方法和经验_系统重构的未来:重构工具 Coca 一周年

一年前,在公司大佬的指点之下,我开始写系统级重构工具 Coca (https://github.com/phodal/coca) 。哦,不,不对,是刚开始学习 Golang,因为我的第一次提交是从一个 Go 的 hello, world 写起的。

commit a685d69080a7abde684e1d0707cbf410092e3173

Author: Phodal HUANG <h@phodal.com>

Date: Tue Oct 22 23:01:19 2019 +0800

first commit

commit c6b5a0c7f174c6a0ba233a1356aca5c370ba4315

Author: Phodal HUANG <h@phodal.com>

Date: Tue Oct 22 23:06:04 2019 +0800

learn: add hello world

时过境迁,这个小工具已经不小了 —— 即使是这个项目的作者,我也要看我写的 README,才会想起来有这么一些功能。这一年来,根据我的一些工作上的需要,陆陆续续地也添加了一些颇为有意思的特性。这些小特性除了不限制编程语言:

501ef794d8ac524514a56718411f8646.png

还可用于指导重构:

3d39ab23d62733f034d7fe6c401dd3c7.png

还可以用于写 PPT 的时候讲述故事:

  • 高频修改文件查找

  • 包结构分析(不限于 Java,大部分的语言是以目录划分包结构的)

  • Todo 分析(可结合历史)

当然了,如果你的系统是 Java 语言主导的话,那么 Coca 能提供更强有力的支撑,具体见:https://github.com/phodal/coca

只是呢,不管我们使用的是什么工具,我们方法论都是类似的。也因此《系统重构与迁移指南》(https://migration.ink/) 成为了系统重构不可多选的材料,Google 『系统重构』 和 『重构工具』会有惊喜。

8df1188003d29eedf8404d02eb76cc7f.png

7c89e5ffee3f599b633270b26e37c9dd.png

系统的必然之路:系统重构 or 重写

没啥说的,部分的系统都是要被重构或者重写的。那么另外一部分呢?他们被淘汰了——要么是产品,要么是公司,笑~。

系统变成了一个大泥球,需求已经越来越难以实现:

fe1018dd36dc6d1473a19782cc09b364.png

真相就是这么简单。如果系统不被指南,和进行频繁的代码级重构的话,那么系统被取代的速度就更快了。

重构 vs 重写

关于系统级别的重构,我们先要讨论的第一个问题其实蛮简单的:我到底是要重构还是重写?选择哪个主要取决于:你要的是技术挑战,还是业务挑战?

哦,不,不对,它取决于你要的是 KPI 是技术 KPI,还是非技术 KPI?说白了,就是价值决定了一切。

对于重构而言,我们所要面对的是技术挑战;对于重写而言,我们所面对的是业务挑战。

重构的技术挑战

我们所面临的主要技术挑战是:

  1. 是否能确保过程的安全性?如何设计测试防护网
  2. 是否能想到更好的设计来取代现有的方案?
  3. 如何做一次有效的分析与评估?
  4. 如何渐进式的重构系统?如何保持小的、快速的提交
  5. 怎样支持未来业务的可扩展?即,支撑业务可扩展性
  6. 是否寻找最合适的重构技巧?比如通过 IDEA 的重构
  7. 如何让重构技能被传承?即,多数团队成员都能快速上手
  8. ……

重写的业务挑战

与重构不同的事,重写时的挑战主要是来自于梳理现有业务:

  1. 如何体系化的整理现有的业务?

  2. 如何剔除已淘汰的业务?

  3. 如何确保主干业务的完整性?

  4. 是否能确保细小的业务功能不被遗失?

  5. 能否设计出更完善的业务知识管理体系?

系统重构的未来

在 Coca 编写完成之后,我发布了《系统重构与迁移指南》一份短小、精悍的重构手册。从这个手册快速的自然增长率(GitHub star 指标,没有经过大量宣传),并且已经在 Google 的相关关键字下(如系统重构、重构策略等)排名第一,我发现了人们缺少一份这样的指南和工具。

所以,在未来一定会有更多的相关工具诞生,并配套有大量的实践指南。

方法论支撑

在开始重构之前,我们需要设计出可行的重构方案,这也就是方法论的支撑。

对于重构的方法论来说,实现上我们已经可以在市面上找到大量的相关书籍,只需要结合起来看就可以了:

  • 《重构与模式》

  • 《设计模式:可复用面向对象软件的基础》

  • 《重构:改善既有代码的设计》

  • 《领域驱动设计:软件核心复杂性应对之道》

  • 《修改代码的艺术:构建易维护代码的 9 条最佳实践》

  • 《代码整洁之道》

  • 《架构整洁之道》

  • 《数据库重构》

  • 《遗留系统重构指南》

  • 《前端架构:从入门到微前端》

工具支撑

市面上,已经充斥着大量代码级重构的工具,如 JetBrians 系列的 IDE。但是,对于系统级重构来说,基本上很少有工具可以直接能支撑现有的系统,哪怕是 Coca 也是有限的支持。主要原因就是:大部分的内部系统都绑定了组织中的模式。特别是对于大型组织来说,它们往往配套开发了自己的底层架构和 API。

也因此,对于系统级别的重构来说,我们要优先考虑的是定制一个工具,又或者是基于开源工具进行扩展。

操作指南支撑

同样的,我们也很难在市面上找到这样的指南,因为对于大部分的公司和团队来说,重写是更好的 KPI,而重构并不会带来如此丰富的价值。除此呢,对于有过重构经验的团队来说,他们也不一定会共享出自己的经验——受能力和保密协议影响。

其它

软件开发总成本 = 开发成本 + 维护成本;软件维护成本 = 理解成本 + 修改成本 + 测试成本 + 部署成本。—— Ken Beck

特别说明 -------- 新版本请访问网站www.bluefishes.net. 考虑到稳定性,新版本不支持Visual Studio.NET 2002. 产品名称 -------- SharpRefactor(C#代码重构工具) 产品简述 -------- 本工具用于代码重构代码自动生成。现阶段主要用于C#代码重构。 所谓重构也就是“保持软件的外在功能不变,重新调整其内部结构”。 关于每种重构模式的含义,请参见http://www.refactoring.com/ 具体功能参见具体版本的特性列表。 对重构很感兴趣或是很关注使用效率的用户,希望[使用指南]一节对你有所助益。 版本 ---- 1.0.0(BETA). 发布日期 -------- 2003/6/13 作者 ---- C# Refactor Team. 制作 ---- Blue Workshop. 环境要求 -------- Visual Studio.Net 2003 Windows 2000 + SP2 + SMTP Service 特别提示 -------------- 本插件使用了异常处理和报告机制。 一般而言,环境、代码以及其他原因都会导致程序出错。因此,在您使用本插件的过程中,可能会弹出错误报告。一部分错误不会影响使用,另一部分会影响使用。 C# Refactor Team愿意随时提供技术支持,及时为你解除问题。 版本1.0.0特性 ------------- Rename Parameter Rename Local Variable Rename Field Rename Property Rename Class Rename NameSpace Safe Delete Parameter Safe Delete Local Variable Safe Delete Field Safe Delete Property Safe Delete Method Safe Delete Class Safe Delete NameSpace Extract Interface Undo/Redo Preview usage before refactor(重构前预览) Auto build after refactor(重构后自动生成) Options(工具选项) User feedback(用户反馈) 使用指南 -------- 所有功能暂不支持静态成员。 尽量使用鼠标右键菜单。 尽量使用快捷方式,比如:单击鼠标右键,弹出菜单后再连续按‘R’键和‘C’键就可以调用[Rename]菜单下的[Rename Class]命令。 在使用Rename系列命令时,需要先转到定义代码元素的地方。此时,可以先使用右键菜单中的[转到定义]命令。 在Option中可以设置首选项。 由于Visual Studio在生成较大的解决方案时有时会不成功,所以Auto build after refactor通常用于较小的解决方案。 Rename NameSpace与Move Class不同。Move Class的焦点在Class,即改变类所在的NameSpace。而Rename NameSpace的焦点在NameSpace,即改变指定NameSpace的名字,并更新该NameSpace的所有引用(Usages)。 错误报告以及建议功能需要网络连接和Windows自带的SMTP服务。因为发送速度很快,所以不会占用您宝贵的时间。 可以使用User feedback功能提出您睿智的建议、批评、任何意见。 技术支持 -------- Tiger.BlueWorkshop@163.net 下载 ---- www.csdn.net 版本 发布日期 ----------------------------- 1.0.0(Beta) 2003/6/13
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值