软件的复杂性与构造定律

2024-01-03 23:38
文章标签 软件 构造 定律 复杂性

本文主要是介绍软件的复杂性与构造定律,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

快看!看!深入研究自然,你就会明白一切。 - 爱因斯坦

复杂性是被低估的。复杂越高,开发人员会感到不安。对其的理解认知负荷代价就越高,我们就更不快乐。真正的挑战是在构建我们的系统时要保持其有序以及工程师的生产方式。对于这一点,一个简单的物理规律可以帮助我们:构造定律 the Constructal Law.

当我们拥有臃肿大量的组件和类时,其中每一个又由大量的职责行为功能组成,我们不会在系统层面去思考,相反,我们只是将大量脂肪性质类进行组群,从外表看,你是无法找出这个系统做什么用的,这个系统代表的,业务需求或用户案例是什么。因为我们的应用程序进行了隐藏。

Neil Johnson, 在其a big proponent of Complexity Science中对复杂系统的定义如下:

(复杂的)系统表现出是一种复杂的有序和无序行为的混合。

对于软件来说,这种复杂的系统一般不是偶然发生的,它它是人类人为的结果。是工程师在以有序和可持续的方式构建组件和系统。    

最聪明的人自从60年代开始在计算机科学已经进行了不少最佳实践。然而,这是不够的。虽然我们已经从自然中得到启发解决了我们的不少困难问题,如神经网络、能源发电和液压。令人惊讶的是,当谈到复杂性,自然也有一种复杂的方法来解决这一问题:在有序和无序中平衡。

 

有序和无序

软件设计者应该是分离应该分离事物,而不是将本应一起考虑的事情进行分离。-Kent Beck

当我们决定打破臃肿的组件分离成小和孤立的部分时,我们面临着一个巨大的编程悖论:起初,一切都是彩虹和独角兽。但是后来,缺非如此。也就是说,事情并没有我们起初想得那么简单。

最初,我们第一次努力隔离后,我们会很高兴。一切看起来是有些紧张的和美丽的。然而,很快事情开始分崩离析,我们最终得到的东西比我们最初的组件要差得多。组件和类变得很大复杂了如下图:

那么下面最自然的事情是什么?放弃,回到我们当初的,继续臃肿的类。这样我们会感觉更好,但实际上我们是在倒退。这些组件不是问题。问题是复杂性,它是一个活着的野兽,会尽一切可能增长,你需要学会驯服它。(Quoting Neil Johnson)

(复杂的)系统似乎是"活着"。系统是在一个高度不平凡的且经常复杂的方式演进发展,这是由一个代理的生态驱动着,这些代理相互作用交互,且在对不断的反馈下不断地适应。

复杂性会增加

让我们将系统的复杂性看成是两个组件之间的许多交互,在两个组件情况下,复杂度是1,如下图:

如果增加一个组件,复杂度将从1增加到3:

复杂度以指数级的增长是惊人的,当我们增加到六个组件,复杂度将是15。

显然,这种拓扑可能是一个极端,但却能公平地明复杂性需要驯服。老实说,这个极端的例子并不少见,这正是人们做的事情,复杂性感染一切。什么出错了吗?

构造定律Constructal Law

自然界是如何应对这复杂呢?这在物理中被称为构造定律 Constructal Law, 仅有的我们知晓的大自然是如何指导复杂演化的规律(可以说是上帝创造万物的方式),是由Adrian Bejan于1995创立的构造定律:

For a finite-size system to persist in time (to live), it must evolve in such a way that it provides easier access to the imposed currents that flow through it.

对于一个有限大小的持续活动的系统,它必须以这种方式发展演进:它提供了一种在自身元素之间更容易访问的流动方式。

这个定理在自然中比比皆是,典型的是树的生长,先有根,再有枝,枝上再生枝叶。这种自发性质的设计反映了这一趋势:他们允许实体或事物更容易地流动 - 以最少的能量消耗到达最远的地方,就连街道和道路这些人为地构建物体,往往也是有排序的模式,以提供最大的灵活性。

构造定律致力于描述能量和物质在物理网络(如河流)和生物网络(如血管)中的流动,这个理论提出,如果一个流体系统(flow system)要继续存在(比如,生存),那么他必须始终提供更容易的方式来获得这个系统中的流体。换句话说,系统应该致力于将能量消耗减少到最低限度,而同时将消耗单位能量产生的熵提高到最大限度

Bejan相信,进化实质上是这么一个过程,即生物体不断的重组他们自身,以使能量和物质能够尽可能迅速高效的通过他们。更好的流体结构(flow structure),不管它们是动物还是河流,将取代那些较差的结构。。

构造定律作为第二个时间箭头,将和热力学第二定律一道将宇宙推向无序。

 

用构造定律进行有序化

回到我们这个复杂系统案例,我们可以使用构造定律降低复杂度,增加第7个组件后,将系统复杂度从15降低到8。

为了实现这种方式开发,你需要了解你的对象不是隔离的实体,而是一个大概念的一部分,比如这个大概念是你的webservice 客户端, 由很多对象组成包括连接 授权和XML文本 响应等。另外一个概念是你的数据库组件,它是由许多对象组成,如ORM Active Record类,校验类 连接类或它们之间的关系,这个大概念是一个聚合群组,聚合了很多子对象于其中,是一个集合概念。

下面以一种模块化分离关注是更加有意义:

 

与构造定律共存

在开发,不要让你的直觉欺骗你以至于产生马虎的代码。不要让一个模块的一部分调用另一个模块的内部组成部分。如下图:

 

对于一个组件A和X个组件之间的交互,每一次A的改变将需要1+ x 改变。

组件之间的交互越少,越好,远离扁平,用模块进行封装,我们能确保我们的系统增加时不会被复杂性淹没。

 

英文原文:Complexity in Software 3: The Constructal Law

加法是自然之道

ORM和Rails的问题

这篇关于软件的复杂性与构造定律的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/567447

相关文章

软件设计师备考——计算机系统

学习内容源自「软件设计师」 上午题 #1 计算机系统_哔哩哔哩_bilibili 目录 1.1.1 计算机系统硬件基本组成 1.1.2 中央处理单元 1.CPU 的功能 1)运算器 2)控制器 RISC && CISC 流水线控制 存储器  Cache 中断 输入输出IO控制方式 程序查询方式 中断驱动方式 直接存储器方式(DMA)  ​编辑 总线 ​编辑

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank 正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

梳理2024年,螺丝钉们爱用的3款剪辑软件

这年头,视频到处都是,就跟天上的星星一样数不清。不管你是公司里的新面孔,还是职场上的老狐狸,学会怎么剪视频,就好比找到了赢的秘诀。不管是给上司汇报工作,展示你的产品,还是自己搞点小视频记录生活,只要是剪辑得漂亮,肯定能一下子吸引大家的目光,让人记得你。咱们今天就来侃侃现在超火的三款视频剪辑工具,尤其是PR剪辑,你肯定听说过,这货在剪辑界可是大名鼎鼎,用它剪视频,既专业又麻利。 NO1. 福昕轻松

秒变高手:玩转CentOS 7软件更换的方法大全

在 CentOS 7 中更换软件源可以通过以下步骤完成。更换源可以加快软件包的下载速度,特别是当默认源速度较慢时。以下是详细步骤: 前言 为了帮助您解决在使用CentOS 7安装不了软件速度慢的问题,我们推出了这份由浪浪云赞助的教程——“CentOS7如何更换软件源加快下载速度”。 浪浪云,以他们卓越的弹性计算、云存储和网络服务受到广泛好评,他们的支持和帮助使得我们可以将最前沿的技术知识分

excel翻译软件有哪些?如何高效提翻译?

你是否曾在面对满屏的英文Excel表格时感到头疼?项目报告、数据分析、财务报表... 当这些重要的信息被语言壁垒阻挡时,效率和理解度都会大打折扣。别担心,只需3分钟,我将带你轻松解锁excel翻译成中文的秘籍。 无论是职场新人还是老手,这一技巧都将是你的得力助手,让你在信息的海洋中畅游无阻。 方法一:使用同声传译王软件 同声传译王是一款专业的翻译软件,它支持多种语言翻译,可以excel

一款支持同一个屏幕界面同时播放多个视频的视频播放软件

GridPlayer 是一款基于 VLC 的免费开源跨平台多视频同步播放工具,支持在一块屏幕上同时播放多个视频。其主要功能包括: 多视频播放:用户可以在一个窗口中同时播放任意数量的视频,数量仅受硬件性能限制。支持多种格式和流媒体:GridPlayer 支持所有由 VLC 支持的视频格式以及流媒体 URL(如 m3u8 链接)。自定义网格布局:用户可以配置播放器的网格布局,以适应不同的观看需求。硬