首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

何时应该重构代码?如何重构代码

日常工作中,相信大家都见过一些看见就想骂人的代码,那么今天呢,我们就来聊聊何时应该重构代码,以及如何重构代码。...重构不止是代码整理,它提供了一种高效且受控的代码整理技术 2.为何重构 改进软件设计:如果没有重构,程序的设计会逐渐变质,重构很像是在整理代码,你所做的就是让所有的东西回到应处的位置上。...何时不该重构:有时候既有代码实在太混乱,重构它还不如重新写一个来得简单。 重写而非重构的一个清楚讯号是:现有代码根本不能正常运作。...3.内联临时变量 有一个临时变量,只被一个简单的表达是赋值一次,而它妨碍了其他重构手法。...常常只使用搬移函数和搬移字段简单地移动对象行为,就可以解决这些问题。如果这两个重构手法都需要用到,我会首先使用搬移字段,再使用搬移方法。

1.6K30

代码重构(六):代码重构完整案例

首先会给出需要重构代码,然后对其进行分析,然后对症下药,使用之前我们分享的重构规则对其进行一步步的重构。...需求很简单而且也不难理解。今天博客会给出原始的代码,也是需要进行重构代码。当然原始代码完全符合需求,并且可以正确执行。废话少说,先看示例吧。...一、需要重构代码 在本篇博客的第一部分,我们先给出完成上述需求需要重构代码。然后在此基础上进行分析,使用之前我们提到过的重构手法进行重构。首先我们给出了电影类的实现。...如果你看代码不太直观的话,下面我使用了startUML简单的画了一个UML的类图来说明上述三个类中的依赖关系。具体如下所示: ? 在对上面代码重构之前呢,我们还必须有上述代码的测试用例。...因为在每次重构之前,我们修改的是代码的内部结构,而代码模块对外的调用方式不会变的。所以我们所创建的测试用例可以帮助验证我们重构后的程序是否可以正常的工作,是否重构后还符合我们的需求。

1.8K70
您找到你想要的搜索结果了吗?
是的
没有找到

代码重构

最近在对手头的项目进行重构,以下是这个过程中的一些思考。 1.项目为什么要重构?...1.2代码无法维护 问题: review代码时,发现很多类似下面的问题: 1.一条sql语句100多行,在sql语句中处理业务; 2.2个饼图2个折线图的数据用一个接口返回,另外一个页面只需要其中2个图的数据...,一年前注释掉的代码还在; 在接手项目的时候,看到这些代码,内心简直是fuck的,在后期数据量不断增大,用户量不断增加,出现问题候,我们来维护这些代码时,充满无力感,一条sql看半天也不知道究竟是在干什么...解决方法: 重构这种代码,是最痛苦的事情了。...; 2.sql语句好好写,你的装x对公司和团队是一种灾难,fuck; 3.写接口思考一下,低耦合啊,方法功能单一一些,这样其他地方或者其他人可以复用啊; 4.没用的垃圾你给删掉啊,别人不敢删你的代码,以为你的代码哪天有用

52030

代码重构(一):函数重构规则

经典的重构书籍中是使用Java语言来实现的,如果你对PHP, Python等其他语言比较熟悉,完全可以使用这些语言来测试一些重构手法。...下方将会通过一个示例来直观的感受一下Extract Method,当然这些示例不是我原创的,是《重构:改善既有代码的设计》中Java示例演变的Swift版,在写Swift代码时,对原有的示例进行了一些修改...当你在重构或者平时编程时,对模块进行了过度的封装,也就是使用Extract Method有点过头了,把过于简单的东西进行了封装,比如一个简单的布尔表达式,而且该表达式只被用过一次。...当然,重构的做法也是非常简单的,只需要术业有专攻即可,各司其职,并且为每个临时变量命一个合适的名字即可。具体做法如下所示。 ?...2.当然重构的手法也特别简单,就是需要将上面的inputVal使用函数的临时变量进行替代即可,下方就是重构后的函数。 ?

1.5K50

代码重构(二):类重构规则

下方代码段是使用Move Method重构后的结果。 ?...当然,对类的细化也是为了减少代码的重复性,以及提高代码的复用性,便于代码的维护。下方将会通过一个实例,对类进行提炼。 1.重构前的代码 下方是我们将要进行重构代码段。...Employee类比较简单。 ? 2.使用Extract Class对Employee重构 接下来要做的就是使用Extract Class对Employee进行重构。...如果过度使用Extract Class原则的话,会使得某些类过于简单并且调用该简单的类的地方极少。...2.使用Hide Delegate进行重构 使用Hide Delegate进行重构的方式是比较简单的,就是在People中封装一个方法,在方法中返回经理的对象即可,这样就隐藏掉了委托关系。

1.2K100

趣图 | 代码重构前vs代码重构

前言 今天跟大家聊一下关于代码重构的话题。 话说,很多程序员对自己写的代码平时很随心所欲(各种魔法变量,一个方法几十上百行代码,还有各种让人崩溃的变量或方法命名)。...当有一天让他维护他人的代码,他就会抓狂,很容易激发他体内重构的瘾。...(大多数程序员审阅完别人代码后,先会忍不住吐槽一番,然后会忍不住想重构一把,) 在我看来,重构本身是一件值得肯定的事,但有个前提,一定不能影响原先业务功能!...重构三技巧 x 一、结构化你的代码 大家看下下面截图assembleOffer这个方法,一个方法内部有很多段代码,比如1.核心商品信息代码片段,2.产品属性信息片段等等。...x 三、对修改关闭,对新增开放 大家如果在重构的时候,面对被修改的代码,其多个地方引用,这个时候一定要小心了,很有可能你改了某一处,但影响了其他功能代码

6210

代码重构之道

代码重构永远是程序员们无法回避的话题,当你的软件在编写的那一刻起,重构就不可避免。...这里我谈谈自己在工作中,对重构的看法。 重构之道 自动化测试 重构代码最最最重要的一个先验条件是:自动化测试。子在川上曰: 一切没有自动化测试的代码重构都是耍流氓。 写代码的目的是什么?...如果重构了十行代码,却需要花费一个小时进行运行一次单元测试,那么你要么不会去重构代码,要么你重构了不会去测试。 好的重构发生在构建系统的每时每刻,而非问题发生或者老板要求。...时时刻刻重构 前面已经提到了重构代码最佳的时间点:撰写每行代码的时候,而非火烧屁股的时候。那什么样的情况你需要进行重构呢?...整个过程和代码重构看上去没什么关系,但处处要求程序员重构代码以达到比较高的标准。相信我,这么做即便大家开始不适,等渐渐建立信心之后,会时时刻刻重构,自我追求更高质量的代码

91440

业务代码重构

刚拿到这个产品的代码时,我也是一头雾水,动就上千行的逻辑代码,看的让人很费劲,完全没有任何套路可言,一撸到底的代码,拿到后,我就先把代码拆开,一块一块的看 ?...最初只有createorder.js,拆开后变成了4个,createordervalidate.js,createorderutils.js,createorderinit.js,拆过之后,代码分工就比较清晰了...重构过之后,编辑,新增订单可以公用一套代码,直接调用对应的方法就行了,即使增加一个查看框,也用不了太久就能搞定,之前的方式就是代码copy,没有抽出业务公共的逻辑。...jquery系列的老的产品代码,最好的重构方法就是插件化,现代三大框架,vue,react,angular,就是组件化,加上,数据状态管理器搞定。

61830

代码重构之道

导语 最近看到有同学提问:“代码重构有意义吗?”,“关于代码重构有什么好的方法论吗?”...,最终事与愿违 1.不懂重构,为了重构重构 不清楚重构目标,不清楚重构范围等,浪费时间在简单的个人偏好上进行代码修改,要搞清楚什么是重构,用它来解决什么问题?...5.不知道结果对不对 对于简单代码级别重构如果做得好是可以不用验证结果的,然对于模块级别或架构级别的重构,是需要的。否则会越做越不知道改的对不对,最终可能重构失败。...子程序级的重构 提取子程序。 将子程序代码内联化。 将冗长的子程序转化为类。 用简单的算法替代复杂算法。 增加参数/减少参数。 将查询操作同修改操作分开来。...如果基类和派生类的代码实现相似,将二者合并。 系统级的重构 为无法控制的数据创建明确的索引源。 将单向类联系改为双向类联系。 将双向的类联系改为单向类联系。 使用工厂函数而非简单的构造函数。

1K10

关于代码重构

为什么要重构重构是软件开发过程中一个重要的事情之一,重构与重写的区别: 重构:不是对已有代码的全盘否定,而是对不合理的结构进行调整,合理的模块进行改动;利用更好的方式,写出更好,更有维护性代码。...重写:已有的代码非常复杂混乱,难以修改,重构的时间还不如重新写一个来得快;根据需求另立一个项目,完全重写。 车子脏了就得洗,坏了就得修,报废了就得换。...程序也一样,不合需求就得改,难于跟上业务的变更就得重构,实在没法改了就得重写。...重构时机 添加功能时 修补错误时 复审代码时 怎样重构 重命名 提炼函数 去除不必要的参数 用对象取代参数 隐藏函数 用常量名替换常量值 用对象取代数组 判断放入循环内,减少循环代码 相同(或及相似)的代码重复出现...减少嵌套的层次,如果有 If 判断,对否定条件提前退出 用设计模式改善代码设计 需求增加,业务变更,需要我们持续重构,持续优化,此恨绵绵无绝期。 ?

54330

代码重构,消灭if

写完后,看着这段代码,陷入了沉思。我写了这段代码,得到了什么。一、完成工作任务。二、。。。(想不出来了)。这不是工具人吗? 随后重新审视了这段代码。一、用到了WebService。二、代码重复率高。...三、代码臃肿,没有区分主干。 那,优化?最近手上的挺多的,而且需要花费半天时间,还得重新测试。 那,不优化?不提升,永远写烂代码。遇到不会的知识不去学习,永远都不会。 答案很明显了,干!...但是这儿太多重复代码了。修改如下: if(!valided(result,A) || !valided(result,B) || !...func(param)){ result="参数"+param+“不合法” return false } return true } 到此,这段代码优雅了许多

20110

代码重构原则

重构目的 相同的代码最好只出现一次 主次方法 主方法 只包含实现完整逻辑的子方法 思维清楚,便于阅读 次方法 实现具体逻辑功能 测试通过后,后续几乎不用维护 重构的步骤 新建一个方法 新建方法(写好伪代码...,根据伪代码写未实现的代码,根据报错,实现方法) 把要抽取的代码,直接复制到新方法中 根据需求调整参数,根据报错向方法名添加参数 调整旧代码 注释原代码,给自己一个后悔的机会 调用新方法 测试 优化代码...在原有位置,因为要照顾更多的逻辑,代码有可能是合理的 而抽取之后,因为代码少了,可以检查是否能够优化 分支嵌套多,不仅执行性能会差,而且不易于阅读 测试 修改注释 在开发中,注释不是越多越好 如果忽视了注释...,有可能过一段时间,自己都看不懂那个注释 .m 关键的实现逻辑,或者复杂代码,需要添加注释,否则,时间长了自己都看不懂!....h 中的所有属性和方法,都需要有完整的注释,因为 .h 文件是给整个团队看的 重构一定要小步走,要边改边测试

71120

代码重构(五):继承关系重构规则

当然还是延续前几篇博客的风格,我们在博客中的代码实例依然使用Swift语言来实现,当然还是那句话,使用什么语言无所谓,关键是看重构的场景以及重构的思想。...“重构”不仅仅可以改善你既有的代码设计,还可以改变你组织代码的思路,使你的程序在设计之初就趋于合理化,利于程序的扩充。...当然Demo看上去不仅简单而且是有些夸张的,不过说明字段上移这个规则是完全足够了的。...重构后的代码如下所示: ? 而将“Pull Down Field (字段下移)”正好与上面的情况相反。...下方代码段是重构后的代码,父类中多出的方法就是我们提取的模板函数,而子类中只给出相应的实现细节即可。 ?

13.4K61

网络研讨会视频:重构还是重写?聊聊 Java 代码臭味与重构技巧

重构一书里,将有问题的代码称作代码臭味(Code Smells,有些翻译成”代码异味”、”代码坏味道”),表示这份代码可能有设计上的问题、或是因为写得太凌乱而难以维护。...本次网路研讨会特别邀请到 Odd-e 敏捷教练张博超(Jackson)为大家演示如何用 IntelliJ IDEA 的重构功能来改善 Java 代码臭味。...让代码更简洁、有更好的表达能力、未来更好维护。在重构的过程中,张博超还提醒我们务必每重构一步,就自动化的运行单元测试,快速验证目前的重构工作是否有改动到原有代码的逻辑。...在分享的最后,张博超为大家提点了什么是重构重构与重写的差别又是什么?简单地说,重构就是在不改变外部行为的情况下,调整代码使其结构更合理或提升可读性。可是这样听起来,重写也能有一样的效果?...所以往往不是很简单的通过提取类就可以结束的,可能要通过很多层的提取,才能将重构完成。 Q. 如何优雅的处理异常,可靠性和优雅可读之间寻求平衡?

67310

趣图|代码重构前vs重构

很多程序员对自己写的代码平时很随心所欲,但当有一天让他维护他人的代码,他就会抓狂,很容易激发他体内重构的瘾。...(大多数程序员审阅完别人代码后,先会忍不住吐槽一番,然后会忍不住想重构一把,) 在我看来,重构本身是一件值得肯定的事,但有个前提,一定不能影响原先业务功能!...可千万别过分自信,觉得说自己没修改多少多少代码,然后就强制发布上线。 这种因为轻视或过分自信,在不自测的情况下,强制上线的生产事故,这两年还少吗。 所以经过充分的单测,才能保障你写的代码质量稳健。...2、对修改关闭,对新增开放 大家如果在重构的时候,面对被修改的代码,其多个地方引用,这个时候一定要小心了,很有可能你改了某一处,但影响了其他功能代码。...这里我有一个建议:不要去修改这种被多个地方引用的代码,你可以新增一个方法:比如重载一个新方法,供你这次的功能调用。然后你在这段新方法内部去重构,这样你的更改,一定不会影响其他功能。

12820
领券