1

重构误区

重构变成了业界最委屈的工程实践之一,管理层不支持,而程序员吃力不讨好。归根结底,是对「重构」错误地理解,给管理层带来很多负反馈。

将事情做好,还得正确地做事。重构是一个系统工程,不仅仅要求雄厚的软件设计素养,同时需要正确的做事方法。

大谬不然

谈及「重构」,管理层谈虎色变,错误地理解或实践重构,必然得不偿失,收效甚微。

  • 这个Bug,就是因为上次重构引入的;

  • 这个模块再不重构,就彻底完蛋了;

  • 系统性能太差,得重构一下;

  • 还没坏就别动;

  • ......

麻木不仁

优秀的程序员对软件设计中存在的坏味道具有敏锐的嗅觉。我所经历的团队,不是因为进度的约束限制重构的工程实践,而是由于缺乏坏味道的嗅觉,长期地麻木不仁。一日皮死麻木不仁,二日肉死针刺不痛,系统就这样每况愈下,腐朽变质了。

孤芳自赏

有的程序员,自我感觉良好,孤芳自赏;实际上,他们往往「不知道自己不知道」,而且这样的程序员心胸都很狭窄,代码犹如尊严一样,绝不容忍侵犯。

直到有一天,知道自己知道了,才觉得那么地无知和可怜。

高处不胜寒

他人笑我太疯癫,我笑他人看不穿。如果两个人没有共同的上下文,没有共同的背景,但硬是要谈到一块,两个人都会很尴尬,很痛苦。

我喜欢优美的软件系统,设计充满着简单的美感,每个软件的元素都是恰到好处,抽象而不至于复杂,直白而不流于形式。

华而不实

重构需要长期的「刻意训练」,并且要求具有良好的软件设计的素养。重构并不是将一种坏味道重构为另外一个坏味道,或者变得更加脆弱,更加复杂。

重构只是手段,关键在于软件设计的修为。只有练就雄厚的内功,方能游刃有余。

主次不分

重构是一个系统工程,如果没有目标,主次不分,很容易迷失自我,吃力不讨好。由点到线,由线到面,各个击破;关注优先级,优先解决最棘手,最重要的问题。

设计欠账

重构应该成为每天的面包和黄油,而不是等到程序变成一个大泥球(Big Ball of Mud),才集中人力实施大规模的重构。

交付压力成为拒绝重构最大的借口,重构并不难,关键在于良好的心态,及其持之以恒的工作态度。

至善至美

至善至美的系统是不存在,因为没有一个统一的标准来衡量。所以,重构一定要有一把尺子,知道自己走了多少,有多大,还离目标有多远。只有短迭代交付,通过正确的反馈渠道,才能赢得管理层的支持。

否则,重构往往变成了项目经理最讨厌的工程实践之一,因为他对重构带来的收益,感觉知之甚少。

重构的本质

「重构」本质是软件设计的过程。这可以从「重构」的定义,目的出发,结合「简单设计」的基本原则,很容易地看出两者是一脉相承的,并且拥有共同的价值观。

何谓重构

重构(名词):对软件内部结构的一种调整,目的是在不改变软件可观察行为的前提下,提高其可理解性,降低其修改成本。

重构(动词):使用一系列重构手法,在不改变软件可观察行为的前提下,调整其结构。

前提

重构是一种「保持行为的等价转换过程」,它是在不改变软件可观察行为的前提条件下进行的软件过程。

目的:使软件更容易地被修改和理解

  • 改进软件设计

  • 使软件更容易理解

  • 使软件没有冗余

重构与简单设计

「简单设计」的四个基本原则,并且重要程度依次减低:

  • 通过测试:Passes all the tests

  • 消除重复:Says everything OnceAndOnlyOnce

  • 揭示意图:Expresses every idea that we need to express

  • 没有冗余:Has no superfluous parts

重构与简单设计一脉相承,相互呼应。改进设计最重要的一个方向就是「消除重复」,确定所有事物和行为在代码中只存在一份表述,这正是优秀设计的根本;重构让代码变得更加容易理解,并准确地表达作者所要的;重构使设计保持简单,使用最少的元素表述软件的行为,避免不必要的复杂度。

重构原则

保持清洁

Try and leave this world a little better than you found it. - Robert Stephenson

「没有坏就不修改」,技术债务与日俱增,最后穷途末路。相反地,应该遵循「童子军规则」,总是保持提交时的代码比签出时更整洁。决不容忍代码中的脏乱,绝不能倒退到坏习惯中去。

循序渐进

对重构理解越深刻,就越倾向于采用更小的,更安全的步骤。欲速则不达,步子不宜迈得太大,否则容易迷失自我,越挫越不勇,从而害怕重构,拒绝重构,从而使得系统腐败变质,陷入恶性循环。

关键还得靠人

招聘最优秀的人

重构需要高超的软件设计的技艺,给他们无法拒绝的收入,给他们自由,相信他们,他们一定不会让你失望的。

给管理层正反馈

快速迭代,持续反馈,让他们能够看到重构的价值,从而赢得管理层的支持。

寻找你的同盟者

找对合适的人,正确的人做正确的事;如果志不同道不合,是很难将事情做对做好。世界这么大,总会碰到一群追梦人,值得去付出努力和青春,因为大家都拥有一个共同的梦想:让软件更加简单,美好!


horance
255 声望29 粉丝

刘光聪,程序员,敏捷教练,开源软件爱好者,具有多年大型遗留系统的重构经验,对OO,FP,DSL等领域具有浓厚的兴趣。