程序原本(九十七):系统的基础部件——系统(我们事实上只能关注可控领域中的可控因素)

阅读数:25 2019 年 10 月 5 日 13:43

程序原本(九十七):系统的基础部件——系统(我们事实上只能关注可控领域中的可控因素)

Joy 都可以煮熟鸡蛋1,但作为架构师的我,却只得出了一个结论:煮熟鸡蛋的可能性似乎连 1% 都不到。

1 其一,看过前言的人应该知道 Joy 是谁;其二,Joy 总是把鸡蛋煮得很熟,这是一种过度的安全措施。

为什么?

因为当架构师看待一件事物时,他看到的是它在系统中的全局问题;而一个实施者,却只需要去做局部的那个部分。当我们把“全局”这个问题牵扯进来之后,任何事情都变得有无限种可能性,因为任何一个系统都是更大系统的局部,而且这个命题是无限递归的。

蝴蝶的翅膀,只是一个生物学的问题;蝴蝶翅膀的扇动,只是一个空气动力学的问题;如此等等。如果我们不能像这样地限定一个系统的领域边界,那么架构师所能得出的结论永远就只有一个:我们什么也做不出来。

所以在大型系统(以及任何一个需要架构的系统)中,我们得承认两点事实:其一,我们的系统永远都只是更大系统的局部;其二,我们只能在实施中关注可控领域中的可控因素。

那么,如何应付未知系统以及那些非可控因素呢?

评论

发布