重构代码,真没有银弹
haoteby 2025-05-23 17:15 62 浏览
译者 | 布加迪
我的一位同事在大型项目代码重构方面有丰富的经验,他真诚地与我分享了他如何处理这些繁杂的任务。虽然他做的大部分事情只是坚持不懈地努力,就像在健身房锻炼那样,但这对我来说很有意义。本文分享他的秘诀。
1、组织目录
当你试图为大型项目重构代码时,很快就会碰壁,因为你不知道一开始该做什么,于是你转而开始阅读O'Reilly的技术类图书,或者对软件开发流程或方法(比如TDD和DDD等)产生兴趣。如果是这样,你的策略将以失败告终。
无论如何,你应该实际做起来,而不是寻找所谓的银弹。首先何不组织项目目录?你可以从了解几个风险入手,因为这么做几乎不会导致错误(bug)。
由于大型项目目录通常很凌乱,所以你一开始会发现很难掌握类的范围、类在何处使用。因此,组织目录可以帮助你在修改类之前了解类在项目中有哪种角色和作用域。
有时,你很难理解某些类的作用。在这种情况下,可以创建一些临时目录,比如“legacy”、“garbage”或之类的目录,并将类文件放入其中。如果你逐渐了解了类的含义,可以将它们移到其他适当的目录。
2、多写注释和文档
即使你已经不得不做代码重构,如果仍认为不需要任何注释以获得干净的代码,那么是时候意识到你的代码不再干净了;你要做的就是写大量注释,即使它们看起来冗长多余。
你应该在读代码时可能会产生疑问的代码旁边留下注释。如果你找到了答案,就应该趁还没有忘记,把它们作为注释写下来。
如果代码与你执行的当前任务无关,你可能不想留下注释。不过请仔细想想。如果你不摆脱一种自我强加的约束,你就无法花时间去注释,也看不到未来开始注释的任何迹象。请注意,它们只是注释而已。
接下来,不妨写你不喜欢写的文档。写文档对于代码重构来说也必不可少,尽管这项工作总是让人感到厌烦,有时甚至让人筋疲力尽。
你可能过去或现在参与几个基于“代码即文档”这一规则的项目。如果把一项特性换成新特性,你将需要阅读所有代码才能理解这项特性的功能。另一方面,如果你有无可挑剔的文档,完全可以使用理想的编程来实现这些特性。
“好奇怪。既然代码最终会被重构,我为什么还要写注释和文档呢?”
这种想法是错误的。代码重构是一项持久的工作。你不确定什么时候可以开始,也不确定是否可以凭一己之力开始。有许多注释和文档在将来供你和同事阅读。
3、编写更多的代码
这听起来似乎很简单,但不是开玩笑。
为了评估工作效率,确认提交和修改了几行代码怎么样?比如说,假设你无法在头一个月完成100次提交和10000次添加或删除,那么你可能需要重新审查计划。
不管怎样,不妨尽可能关注编程。你不必事先考虑架构、测试、编程规则或之类的事情,因为你可以边编程边考虑这些事情。如果你首先正视代码编写,就会找到与项目兼容的度量指标。
“你的意思是,我必须一开始就要重写我写的所有代码,是吗?”
是的,你说得对。如果你犯了错误,就重写代码。没有人能够在不遇到失败的情况下完成代码重构。
“话虽如此,还是很难挤出时间写这么多的代码。”
你可能会遇到一些问题,比如办公室会议太多、项目前期时间太长,或者你自身的技能不足。然而,没有什么是一蹴而就的。同样,你没必要寻找银弹,只需不断地努力。
有志者,事竟成。
原文链接:https://medium.com/@
cafedeichi/massive-project-code-refactoring-tips-4a973c3bcc7f
来源: 51CTO技术栈
相关推荐
- 统统都能轻松装下。_如何安装统赢
-
今天必须来好好聊聊迈腾甄选款的外观升级优势,简直是把经典与时尚玩明白了!迈腾甄选款巧妙地保留了迈腾的经典气场和造型,就像一位历经岁月沉淀却风采依旧的绅士。2871mm的超长轴距搭配超短前后悬设计,这就...
- 麒麟操作系统常见问题:打开火狐浏览器提示没有安装flash插件
-
关键词:火狐浏览器、flash、插件、安装问题类型:...
- VS Code 新手必装插件清单_vs code 安装插件
-
以下是针对VSCode新手的必装插件清单,覆盖代码编辑、效率提升、美化等核心需求,适用于大多数开发场景:一、基础必备插件Chinese(Simplified)(简体中文)功能:将VSC...
- 开源JSON可视神器,让阅读JSON变得简单!-JSONHero
-
众所周知,现在有不少代码编辑器以及在线工具,都支持JSON格式化,因此这一特性,已经不能称的上是亮点。调试工具已经成为每个开发者不可或缺的“利器”。但是,你见过能直接可视化JSON数据,把整个...
- 在NAS上部署Barcode服务_nas basic
-
部署基于BWIP-JS的条形码生成APIBWIP-JS是一个优秀的JavaScript条形码生成库,它支持多种条形码类型,并且可以运行在Node.js环境下,非常适合用来构建API服务。...
- 详细介绍一下Python如何对JSON格式数据进行处理?
-
在Python中对于JSON数据的处理是在日常开发中的常见需求之一。通常情况下,对JSON数据的处理主要涉及到如下的的几个步骤对于JSON数据的解析操作对于JSON数据的处理操作对于JSON数据的格式...
- golang2021数据格式(69)Go语言将结构体数据保存为JSON格式数据
-
JSON格式是一种对象文本格式,是当前互联网最常用的信息交换格式之一。在Go语言中,可以使用json.Marshal()函数将结构体格式的数据格式化为JSON格式。想要使用json...
- 一个vsCode格式化插件_vscode 格式化文档
-
ESlint...
- 自己抓取家中IPTV组播地址,不用交换机或多网卡,远程抓取更方便
-
通过IPTV播放应用在电视、电脑或者手机观看家中的IPTV电视直播,可以摆脱IPTV机顶盒的限制,方便在家中多台电视或者手机电脑上观看IPTV电视直播。运营商IPTV的电视直播信号稳定、高清,和互联网...
- 扣子免费系列教程, 如何使用扣子(coze)对接飞书多维表格?
-
一、说明大家都知道使用扣子(coze)把一些文本内容转为小红书风格很方便。但每次都是复制粘贴。很麻烦那能不能批量呢?今天我们就来学习下,使用扣子(coze)平台完成内容的批量转换。基本思路是读取飞书多...
- 1024程序员节 花了三个小时调试 集合近50种常用小工具 开源项目
-
开篇1024是程序员节了,本来我说看个开源项目花半个小时调试之前看的一个不错的开源项目,一个日常开发常常使用的工具集,结果花了我三个小时,开源作者的开源项目中缺少一些文件,我一个个在网上找的,好多坑...
- 办公人必看!3分钟搞定JSON/XML/Markdown,格式转换竟如此简单!
-
你是不是也遇到过这些情况:领导突然甩来一份密密麻麻的数据文件,要你半小时内整理成报表;想写技术文档,却被Markdown的语法搞得头大;或者同事发来的JSON文件,打开全是“{”“}”“,”,看得眼花...
- 开发者必备!zerotools.top全栈效率神器
-
强烈建议开发者们收藏https://zerotools.top,用它来提升日常效率。一、功能覆盖:从数据到图像的全栈支持Zerotools.top的最大亮点,是其功能维度的完整性。根据最新页面...
- 15 个非常好用的 JSON 工具_json tools
-
JSON(JavaScriptObjectNotation)是一种流行的数据交换格式,已经成为许多应用程序中常用的标准。无论您是开发Web应用程序,构建API,还是处理数据,使用JSON工具可以大...
- C#.NET Newtonsoft.Json 详解_c# jsonresult
-
简介Newtonsoft.Json(又称...
