软件之禅(十一) 消息

黄国强 2024/03/30

        图灵机三个部分:纸带,读写头,控制器之间是通过消息来交互的。消息有多种形式,举一个最常见的一个例子,我们调用一个函数或过程,这可以认为是向这个函数或过程发了一个消息。
        从耦合的角度,我认为消息分为以下三种:
        * 情形1,只发送,不关心是否收到,即广播消息,类似于网络通讯的IP协议和Redis的频道消息
        * 情形2,发送消息并确保客户端一定收到
        * 情形3,发送消息并确保客户端收到并执行指定的任务,典型的就是函数调用
        显然,情形1耦合度最低,情形3耦合度最高。如果一个系统中都是情形1的模块,那么开发和维护这种系统是非常轻松的。当然整个系统都是情形1这种情况是极小概率的事情,大多数系统这三种情形都会存在。
        大型软件架构的顶层设计,一定是设计成情形1。其他情形扩展性会有问题,而且复杂度会很高。从心理学的角度来看,人类处理信息的能力是有限度的。根据米勒(Miller,1956)的分析,人脑处理信息有一个魔法数字7(正负2)的限制,也就是说,人的大脑最多同时处理5到9个信息(chunks)。原因是短期记忆储存空间的限制,超过9个信息团,将会使得大脑出现错误的概率大大提高。
        所以基于米勒法则的考虑,我们要从设计的角度尽量减少“调用且需要跟踪结果”的这种情形3的情况。一个公司为什么尽量用规章制度管理,而不是人治,背后的道理也是相通的。我之前的blog“集中决策和分散决策”系列文章讲了两个具体设计的优劣。读者有兴趣可以看看。

[参考链接]
米勒法则
集中决策和分散决策(1) (2)(3)
软件之禅(十)数据库
 

相关推荐

  1. 软件消息

    2024-03-31 18:40:07       36 阅读
  2. Python

    2024-03-31 18:40:07       54 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-31 18:40:07       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-31 18:40:07       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-31 18:40:07       87 阅读
  4. Python语言-面向对象

    2024-03-31 18:40:07       96 阅读

热门阅读

  1. vim的缓冲区管理技能

    2024-03-31 18:40:07       34 阅读
  2. ChatGPT:学术界必备的写作利器

    2024-03-31 18:40:07       36 阅读
  3. C 语言练习分享

    2024-03-31 18:40:07       38 阅读
  4. leetcode 64.最小路径和

    2024-03-31 18:40:07       36 阅读
  5. vue组件的select怎么赋值?

    2024-03-31 18:40:07       43 阅读
  6. Leetcode-2952-需要添加的硬币的最小数量-c++

    2024-03-31 18:40:07       38 阅读
  7. C++多线程:unique_lock源码分析与使用详解(六)

    2024-03-31 18:40:07       38 阅读
  8. 为什么Redis设计成单线程

    2024-03-31 18:40:07       38 阅读
  9. 2952. 需要添加的硬币的最小数量

    2024-03-31 18:40:07       45 阅读
  10. Python计算物理粒子及拉格朗日和哈密顿动力学

    2024-03-31 18:40:07       39 阅读
  11. 非计算机专业如何入门深度学习

    2024-03-31 18:40:07       42 阅读