50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

重建还是重构?

  • 2015-12-02
  • 本文字数:2302 字

    阅读完需:约 8 分钟

Agile Testing Days 2015 大会上, Wouter Lagerweij 谈到了如何重建一个遗留系统而不是重构它,来帮助团队采取敏捷实践,比如测试驱动开发,自动化测试,持续交付。他的谈话基于他的博客文章 Don’t Refactor. Rebuild. Kinda

InfoQ 采访了 Lagerweij 关于是什么让重构如此困难,重建软件的风险是否比重构小,以及持续交付如何配合软件的重建。InfoQ 同时请教了他关于重建和重构的建议。

InfoQ:您能解释一下是什么使得重构这么困难吗?

Lagerweij:只要你去做,重构是一项相当简单的实践。同样的例子是单元测试。只要你坚持为代码编写测试用例,或者清理代码中的设计问题,一小步一小步的,这并不困难。

可是你越是把这些丢在一边,捡起来的时候就越困难。这就是为什么每个人都一直说“技术债务”。可是实际上它通常不是指 Ward Cunningham 所创造的技术债务(参见 Ward Explains Debt Metaphor )。

软件行业并不是唯一发生这些事情的地方。只是询问一些活跃在医疗保健行业的专业医师。了解到外科医生坚持在手术前洗手能降低一半的手术并发症,但是即使有积极的宣传和结构化的清单,它依然很难被遵守。

所以,由于一些团队推迟重构,我们有一些混乱,或者说“遗留代码库”。由于这些团队几乎总是没有足够的重构经验(否则他们已经这样做了),他们无疑不能完成修复这些混乱代码的工作。

此时这些团队认识到他们应该为他们的“债务”做些事情,他们不得不接受一个系统,在其中努力学习用以提升自己系统的技能!当小的改动在系统的不同部位导致不可预知的结果时,是对重构中积极的学习经历不利的。而且任何开发人员都知道为封闭的,紧耦合的系统添加单元测试是一个困难和不愉快的经历。

我想我要说的是,如果你等到遇到这些麻烦才开始学习这些技能,很可能你将不会成功的应用它们。也就是说,在掌握它们之前,你更可能会先放弃它们。

InfoQ:在您看来重建软件比重构的风险更小?您能解释一下吗?

Lagerweij:说实话,如果你的团队成员知道如何去改进一个遗留系统,重构始终是更好的选择。它的风险更小,并且比任何类型的重写的开销要少。

但是不幸的是这些技能仍然非常稀少。如果团队中的成员之前没有做过这类工作,之后你的所有工作都会慢于预期。你会在开发团队和公司中增加挫败感。

有一些组织发现自己陷入了困境。他们简直没有专业人员来解决他们的技术问题。他们不能构造有竞争力的新功能。甚至找到几个有经验的人也很难,常常是“太小,太迟”的情况。

这种情况下重写是更有吸引力的。

InfoQ:您能给出一些例子来展示团队如何来重建软件以及做持续交付吗?是什么让它们成为一个好的组合?

Lagerweij:重写的一个好处是你能重新开始。这意味着这次你能确保你这样做是正确的。当然,大多数时候,你不能。就像我之前说的,处理这些事情最好的方式,例如测试和重构,就是持续不断的做。但是如果你之前从来没有做好过,它怎么会突然就能工作?

我在谈话中说过的,我们已经在我当前工作的团队试过。我们使用测试驱动开发(也叫做行为驱动开发),我们会保持代码的整洁,确保始终有 100% 的单元测试覆盖率。他们不再害怕他们的遗留系统,他们知道他们能够做到这一点。

我们也同意,确保我们不会受到放松控制的诱惑,我们从第一天起就做到完全的持续部署。这意味着开发者每次推送代码到 GitHub 中时,它会自动构建,测试并部署一直到生产。这使得我们任何时候都能极好的关注在保持高质量上。你不能推迟那些测试,因为推送未测试的代码会破坏构建,使得整个团队等着你。但是你也不想跳过测试(或者写一个未检查的单元测试只是为了糊弄覆盖率),因为你实际上可能破坏生产。你自己,很明显。

还有一些简单的心理作用,没有人真正关心什么让测试覆盖率从 2.1% 到 2.0%,但是当它从 100% 掉到 99.9% 时,整个团队会要求一个解释。

你仍然需要经历一个学习过程。重新开始并不会让你突然做的更好。它只是创造一个更大成功率的机会。

InfoQ:对于正在考虑用重建软件代替重构的团队,您有什么建议?

Lagerweij:首先,在发布之前不要尝试和重建任何东西。找到一种方式将新系统和老系统融合,并尽快为你的新系统的用户提供价值。有些东西比如 strangler pattern branch by abstractio 能帮助你。如果你不这样做,你的项目要么在某个时候被取消,要么永远继续下去,但无疑不会有好的结果。

其次,停止糊弄自己。使用一个严格要求规定的工具,比如持续部署,会感觉在项目的表明需求上增加了额外的负担,但是这个规定会帮助你避免陷入和之前同样的陷阱,写出一个完全的新的遗留系统。它会促使你学习新技能,例如持续重构,如何测试驱动你的代码,有多少种不同类型的测试需要被掌握,如何自动化部署,如何处理监控和错误处理。所有的这些都是和到生产的途径变得短和直接紧密相关的。

最后,可能是最重要的,涉及到客户!尽管比通常的要多,重写的诱惑是得到“和老系统做同样的事”的响应,而不是因为客户交流有任何进一步的需要。但是我们需要知道客户现在需要什么。我们也需要知道他不再需要什么。我们都熟悉 80/20 法则关于被使用的功能。你看,重构不仅仅只是发生在代码层面,审查你的需求,业务流程甚至是商业模式都是同样的重要。

当然,它仍然会有大量的工作要做,但是如果你坚持这些原则,一旦你做到了,你会得到干净的代码,一个学习型团队,和高兴的客户。

查看英文原文: Rebuild or Refactor?


感谢张龙对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群(已满),InfoQ 读者交流群(#2))。

2015-12-02 18:003020

评论

发布
暂无评论
发现更多内容

2025最新版Java面试八股文PDF

Geek_Yin

编程 程序员 java面试 Java面试题

快手基础大模型团队7篇论文入选人工智能领域顶会ACL 2025

快手技术

acl 快手 论文解读 学术成果

昇腾NPU上基于MindIE服务的AIME和MATH500测评方案

小顺637

大模型 昇腾

AI本地化部署的流程

北京木奇移动技术有限公司

AI技术 软件外包公司 AI本地化

AI本地化部署的优势

北京木奇移动技术有限公司

软件外包公司 AI本地化部署 AI本地化

数据太多、系统太慢、调度太乱?电力行业最全数据难题全在这份白皮书里

TDengine

数据库 tdengine 时序数据库

最全的Java面试八股文合集

Geek_Yin

编程 程序员 java面试 Java面试题

Java基础八股文面试题总结+答案解析

Geek_Yin

编程 程序员 java面试 Java面试题

Redis 数据恢复的月光宝盒,闪回到任意指定时间

百度Geek说

P4.81户外租赁LED显示屏全面解析

Dylan

LED LED display LED显示屏 市场 LED屏幕

苹果mac高效协同办公:Slidepad自动隐藏、快速搜索、多桌面支持

Rose

AI 本地化部署的详细方案

北京木奇移动技术有限公司

软件外包公司 AI技术应用 AI本地化部署

时序数据库 TDengine 带着三大石油项目落地实践,亮相 2025 中国石油石化大会

TDengine

数据库 大数据 tdengine 时序数据库

beyondcompare5永久激活密钥 及 Beyond Compare安装教程

Rose

Amadeus Pro: 专业音频编辑,Mac 用户的终极选择!

Rose

Java面试八股文大全(附各大厂面试真题及答案)

Geek_Yin

编程 程序员 java面试 Java面试题

鸿蒙仓颉语言开发教程:仓颉语言中的状态存储

幽蓝计划

埃文科技智能数据引擎产品入选《中国网络安全细分领域产品名录》

郑州埃文科技

背完这套 Java 面试八股文,offer拿到手软

Geek_Yin

编程 程序员 java面试 Java面试题

什么是Redis缓存穿透?redis面试题及答案乐分享(附面试题大全)

程序员高级码农

redis 程序员

TikTok账号被封原因及IP关联问题解决办法

Ogcloud

TikTok 云手机 海外云手机 tiktok运营 tiktok封号

如何批量查询手机号码归属地,在线工具平台,可按省份分离、按城市分开、按号段分类、按移动联通电信来分别导出excel。

飞舞的键盘

“一代更比一代强”:现代 RAG 架构的演进之路

Baihai IDP

AI LLM 检索增强生成

GPU性能怎样影响大模型训练速度?

Ogcloud

gpu 服务器 服务器租用 gpu 算力

深度解读「高盛」人形机器人双研报:主流人形机器人公司梳理和商业化瓶颈(附报告)

机器人头条

科技 大模型 人形机器人 具身智能

中科大、月之暗面等开源对话式语音合成模型 MoonCast;ChatGPT 发布「录音模式」,自动录音和生成会议纪要丨日报

声网

家具工厂MES生产管理系统解决方案

万界星空科技

制造业 mes 万界星空科技mes 家具行业 家具mes

DePIN的底层逻辑:让物理基础设施加速市场化

PowerVerse

加密货币 去中心化 算力 #区块链 DePIN

HTTP2.0 从原理到实践,保证把你治得服服帖帖!

左诗右码

郑州工程技术学院赴埃文科技开展访企拓岗促就业活动

郑州埃文科技

重建还是重构?_架构_Ben Linders_InfoQ精选文章