软件复杂性

Posted sunshine-blog

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了软件复杂性相关的知识,希望对你有一定的参考价值。

 参考文章:

阮一峰:http://www.ruanyifeng.com/blog/2018/09/complexity.html

 

软件复杂性:

  • 软件设计的最大目标,就是降低复杂性。 所谓复杂性,就是任何使得软件难于理解和修改的因素。
  • 复杂性的来源主要有两个:代码的含义模糊 和 互相依赖
  1. 模糊指的是,代码里面的重要信息,看不出来。
  2. 依赖指的是,某个模块的代码,不结合其他模块,就会无法理解。
  • 复杂性的危害在于,它会递增。你做错了一个决定,导致后面的代码都基于前面的错误实现,整个软件变得越来越复杂。"我们先把产品做出来,后面再改进",这根本做不到。

如何降低复杂性:

  • 降低复杂性的基本方法,就是把复杂性隔离。"如果能把复杂性隔离在一个模块,不与其他模块互动,就达到了消除复杂性的目的。"
  • 改变软件设计的时候,修改的代码越少,软件的复杂性越低。
  • 复杂性尽量封装在模块里面,不要暴露出来。如果多个模块耦合,那就把这些模块合并成一个。

接口和实现:

  • 模块分成接口和实现。接口要简单,实现可以复杂
  • 好的设计是,大量的功能隐藏在简单接口之下,对用户不可见,用户感觉不到这是一个复杂的 class。

对用户减少抛错:

  • 除了那些必须告诉用户的错误,其他错误尽量在软件内部处理掉,不要抛出。

 

以上是关于软件复杂性的主要内容,如果未能解决你的问题,请参考以下文章

1 软件系统的复杂性

《领域驱动设计:软件核心复杂性应对之道》读书笔记

翻译软件设计的哲学-2 复杂性的本质

编程思想进化史与软件复杂性

翻译软件设计的哲学-1 介绍(一切都是关于复杂性)

研究思考丨关于软件复杂度的困局