【软件】重构与架构

什么是重构

重构是指在不改变代码行为的前提下,重写代码,使其更加简洁,易于服用

这是核心技能,并且经常我们在自己没有意识到的情况下使用

什么是软件架构

就像生物一样,软件系统通常由很多较小的部件组成,每个部件擅长做一件事。将这些部件组合起来,一起工作,可形成更大的软件系统。术语软件架构用来描述软件项目的各个不同部件之间的组合方式。

笔者的理解就是软件架构就是在拼装高达

优秀架构是可预测的

软件架构可预测是指可以对软件的工作方式和结构做出准确的假设。可预测性表明预先的规划是合理的,并有助于节省开发时间,因为可以避免下列问题:

  • 组件的功能是什么
  • 某一段代码在何处
  • 新代码加到何处

在可预测的架构中,人们可以做出精确的假设,不熟悉代码的开发人员也能够更快地理解该架构。

优秀架构可提升代码复用性

代码复用是指在多处使用同一代码而无需重写。代码复用优势明显,不用重写已有代码,可以加快开发速度。同理,解决某一问题所需的代码越少,维护所有用该代码实现的功能
所需的时间就越少。

优秀架构可扩展

跟可扩展性非常类似,可维护性对于架构也很重要。对于可维护的优秀架构,修改其现有功能很容易。随着时间的推进,需求也许会发生变化。迫于需求变动的压力,你将修改代
码。可维护性软件是指你修改一处代码时,没必要大规模改动其他代码。

软件架构和重构

重构有助于维护和提升软件架构。

重构就是指调整代码结构、使其更具意义的一套技术。重构可使代码可预测、可复用、可扩展和可维护。

当你的软件架构具备了上述特点时,它对目标用户而言将更可靠,你在其上继续开发也会更加愉快!

需要重构的原因

  1. 需求变更
  2. 架构设计不合理
  3. 低估困难
  4. 忽视最佳实践

什么情况下应该重构代码

结合代码的上下文重构代码会更加容易。

因此,如果你修复的 bug 或开发的新功能用到了已有代码,重构是最好的选择。

处理小任务时顺便重构代码,不至于把一切搞乱,他人若修改你重构过的代码也能从中受益。

不断坚持重构代码,代码质量将达到卓越,前提是你的改动符合优秀架构的特点。

然而,有时你会遇到一段有很多依赖的代码,也许需要决定是否对其重构。

重构有很多依赖的代码,就像抽衣服上的线:抽得越多,散开得越多。

类似地,对于具有很多依赖的代码,你改动得越多,需要更新的依赖就越多。

遇到这种情况,如果时间很紧,先把工作完成也许更适合,然后再匀出些时间,回头审视并重构代码。

然而,如果开发过程中重构某些小功能不至于严重影响到开发计划,你也许可以考虑及时重构它们。

什么情况下不应该重构代码

知道什么情况下不应该重构,甚至比知道什么情况下应该重构更为重要。

重构名声不太好,因为有时看起来软件开发人员只是为了重写而重写。

代码也许是别人写的,没必要重构,但患有“不是我写的症”的开发人员一定要对其重构,因为他们认为不是自己写的代码就不是好代码。

或者,有一天开发人员心血来潮,不再喜欢之前的代码编写方法(也许之前类名使用下划线而不是连字符,现在想改过来),因此他们钻入重构的兔子洞以求止痒。

很多情况下,这些工作被视为“磨洋工”,它让人们感觉效率很高,事实上并非如此。

你可能感兴趣的:(【软件】重构与架构)