分离、解耦是模块化的基础。概念、功能上的辨异,又是实现分离、解耦的法门。
- 模块间通信:接口;
- 模块间绝非各自为营,独立作战;
- 业务与管理的分离;
- 数据与控制的分离;
- 用户面,信令面;
- 数据链路,控制链路
- 数据与控制的分离;
逻辑与视图分离
- 逻辑是功能性代码,视图是内容,展示性代码;
- 视图为逻辑提供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 放到单独的包中,使它与其他的应用程序在物理层面分离开来,这样对它的意图就不会产生困惑了;
- JavaConfig 与其他的(普通的) Java 代码是不同的,在概念上,它与应用程序中的业务逻辑和领域代码是不同的;
2. 内聚
- 内聚性的实现:把经常一起变化的部分(联动)放在一起;
3. 生活中的范例
- 对于小诊所,一般两个工作人员,一个前台看病,开药方,顺便划价收费,一个后台抓药,取药;
- 等到医院越来越现代化,每天接受的病人越来越多,显然两个人根本应付不过来,此时便会将各自承担的责任分离,将彼此独立的模块置于同一个模块;
- 导医台
- 挂号处;
- 诊室;
- 划价;收费;
- 取药;
- 等到医院越来越现代化,每天接受的病人越来越多,显然两个人根本应付不过来,此时便会将各自承担的责任分离,将彼此独立的模块置于同一个模块;