跳转到主要内容
类别:定律
类型:系统设计定律
起源:系统论,1975年,约翰·盖尔
别名:盖尔法则、复杂系统演化
快速回答盖尔定律是一个原则,指出每个有效的复杂系统都是从有效的简单系统演化而来。这一定律由约翰·盖尔于1975年提出,表明复杂的系统最终是脆弱的并倾向于失败,而已被证明有效的简单系统为开发提供了更可靠的基础。

什么是盖尔定律?

盖尔定律提出,复杂的、全功能的系统不能从零开始设计或开发——它们必须从更简单的有效系统演化而来。核心洞察是,成功的复杂系统不是通过全面的规划做到这一点的,而是通过迭代开发实现的,在每一阶段都建立在已经工作的基础之上。
“一个有效的复杂系统总是被发现在它之前是从一个有效的简单系统演化而来的。”
这一原则挑战了试图预先设计完美系统的方法。相反,它表明通往复杂、有效系统的道路需要经过经过验证的简单性。每个成功的复杂系统都是更简单祖先的后代,这些祖先已经解决了核心问题。

盖尔定律的三层理解

  • 入门:在构建新东西时,从解决核心问题的最简单版本开始。不要试图立即构建完整解决方案——首先证明基本概念有效。
  • 实践:在评估提出的解决方案时,评估它们是否从有效的更简单版本演化而来。“设计”出来的复杂系统而非演化出来的往往以意想不到的方式失败。
  • 进阶:理解演化需要选择压力。简单系统通过在现实条件下的迭代成为复杂系统——而非通过假设规划。

起源

盖尔定律归功于约翰·盖尔(John Gall),一位系统论作者,在其1975年出版的《系统论:系统如何真正运作及如何失败》一书中提出。盖尔正在分析大规模系统——无论是技术还是组织——为何如此频繁地失败,他观察到成功的复杂系统背后总是有有效简单性的历史。 这一定律来自盖尔对各个领域系统失败的研究,包括军事、政府和企业组织。他的关键洞察是,架构师和设计师经常认为他们可以计划所有意外,但最终现实世界的复杂性击败了这种全面设计。唯一生存下来的系统是那些通过实际使用被测试、改进和扩展的系统。

核心要点

1

复杂系统需要经过验证的基础

你不能从概念跳到复杂的实现。每一层复杂性必须建立在已经工作的一层之上。没有这个基础,你就是在沙子上建房子。
2

在复杂领域演化胜过设计

在具有许多相互依赖变量的系统中,演化开发优于预先设计。真实使用的选择压力揭示了规划无法预见的问题。
3

简单不是阶段,而是基础

简单的版本不仅仅是原型——它是必须工作的核心。所有附加的复杂性必须服务而不是破坏这个经过验证的基础。
4

失败是信息性的

当复杂系统失败时,问题通常不是复杂性本身,而是缺乏一个被适当测试的有效的简单前体。

应用场景

产品开发

成功的产品通常从一个解决一个问题的最小可行产品(MVP)开始。在证明核心之前添加功能会产生在负载下失败的脆弱产品。

软件架构

在设计软件系统时,从满足当前需求的最简单架构开始。只有在实际使用模式证明必要时才添加复杂性。

组织设计

当组织建立在已经工作的结构上时,组织演化得更成功。重大重组经常失败,因为它抛弃了经过验证的模式,转而支持未经测试的设计。

创业策略

初创公司首先找到简单、经过验证的商业模式,然后扩大复杂性,从而取得成功。那些在产品-市场匹配之前筹集大量资金来构建复杂系统的公司经常失败。

经典案例

万维网的演化

万维网提供了一个引人注目的盖尔定律实际例证。蒂姆·伯纳斯-李在1989年的原始设计非常简单:一个由超链接连接的文档系统,通过一个基本浏览器访问。 这种简单性——文档和链接——是”有效的简单系统”。它解决了一个特定问题:在 CERN 的不同计算机之间共享信息。这个系统非常简单,以至于可以在一个研究机构内实现、测试和证明。 从这个简单的基础,万维网演化了。添加了额外的层:JavaScript 的图像和交互性、服务器端编程的动态内容、用户身份验证、电子商务、社交功能和移动访问。每一层都建立在有效的基础之上。 关键的是,如果原始万维网从一开始就想包含所有这些功能,它就会失败。复杂性将是无法管理的,设计决策将在没有现实世界反馈的情况下做出,系统将因自身重量而崩溃。相反,万维网一层一层地演化,每一添加在尝试下一层之前都被证明是有效的。 今天,万维网比伯纳斯-李最初的愿景复杂得无法想象——但这种复杂性是通过演化获得的,而非预先设计的。

边界与失效场景

盖尔定律有重要的局限性:
  1. 并非适用于所有领域:有些系统可以从零开始成功设计——尤其是当需求被很好地理解且领域受到限制时。
  2. 演化需要正确的条件:驱动演化的”选择压力”必须是真实的和有信息的。在快速变化的环境中,演化可能没有时间在工作之前条件就发生变化。
  3. 简单可能是不够的:有些问题真正需要从一开始就使用复杂的解决方案。关键在于区分过早的复杂性和必要的复杂性。
  4. 路径依赖很重要:一旦系统以特定方向演化,改变该方向变得越来越困难。早期决策约束未来选项。

常见误区

盖尔定律不是说简单更好——而是说简单必须首先出现。目标是最终达到有用的复杂性,但只有在证明基础之后。
虽然演化需要时间,但数字系统可以通过迭代快速演化。关键是现实世界的反馈,而非日历时间。
盖尔定律并不拒绝规划——它建议规划应该专注于创造演化的条件,而非全面设计。你规划基础,而非大教堂。

相关概念

最小可行产品

构建可以验证假设的最简单版本的概念——直接应用盖尔定律到产品开发。

迭代开发

通过重复周期构建产品,每个周期都建立在前一个周期之上——体现了盖尔定律描述的演化方法。

康威定律

系统设计反映组织沟通结构的洞察——补充了盖尔定律,解释了为什么演化走特定的路径。

一句话总结

首先构建一个有效的简单系统——然后演化它。成功的复杂系统是一层一层建立在经过验证的基础之上的。