计算机设计思想 —— 解耦(分离)与内聚

时间:2024-02-23 17:45:47

分离、解耦是模块化的基础。概念、功能上的辨异,又是实现分离、解耦的法门。

  • 模块间通信:接口;
    • 模块间绝非各自为营,独立作战;
  • 业务与管理的分离;
    • 数据与控制的分离;
      • 用户面,信令面;
      • 数据链路,控制链路
  • 逻辑与视图分离

    • 逻辑是功能性代码,视图是内容,展示性代码;
    • 视图为逻辑提供get方法,逻辑提供set方法,如下的Android代码:
    public class MainActivity extends AppCompatActivity {
        @Override
        public void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.hello_world_layout);
                    // R.layout.hello_world_layout 便是界面布局性代码;
        }
    }

1. 配置代码与业务逻辑(领域代码)

  • Spring 框架下,使用 JavaConfig 进行显式装配的时候,要注意:
    • JavaConfig 与其他的(普通的) Java 代码是不同的,在概念上,它与应用程序中的业务逻辑和领域代码是不同的;
      • JavaConfig 是配置代码,也就有意味着它不应包好任何业务逻辑,JavaConfig 也不应当侵入到逻辑代码中;
    • 尽管不是必须的,通常会将 JavaConfig 放到单独的包中,使它与其他的应用程序在物理层面分离开来,这样对它的意图就不会产生困惑了;

2. 内聚

  • 内聚性的实现:把经常一起变化的部分(联动)放在一起;

3. 生活中的范例

  • 对于小诊所,一般两个工作人员,一个前台看病,开药方,顺便划价收费,一个后台抓药,取药;
    • 等到医院越来越现代化,每天接受的病人越来越多,显然两个人根本应付不过来,此时便会将各自承担的责任分离,将彼此独立的模块置于同一个模块;
      • 导医台
      • 挂号处;
      • 诊室;
      • 划价;收费;
      • 取药;