是什么
模块可以承载策略或实现。但是,一个模块不可以同事承载二者。
- 策略模块
策略模块依赖于软件的前提条件,这类模块通常用于给业务逻辑或其他模块选择参数。
- 实现模块
实现模块不依赖于软件的前提条件,这类模块通常是独立的逻辑部分。软件的前提条件会作为传递给模块的参数给出。
为什么
实现模块不依赖于特定的软件,是一种纯粹的模块,因此可供其他软件重复使用。
而策略模块是为了特定软件量身打造的。当软件发生变动时,策略模块也要被迫发生改变。因此如果将实现和策略混在一起,那么当策略发生变动时,实现也会受到牵连,影响模块的重复使用。
怎么做
设计时要有意识地区分依赖于软件前提条件的策略部分和不依赖于软件前提条件的实现部分,然后将二者分别写入不同的模块。
当遇到无法分离的情况时,至少要在模块内部明确区分策略部分和实现部分。
另外,即便最初分离了策略与实现,在维护代码的过程中二者也可能会重新混在一起。因此在开展修改工作之前,要明确修改对象到底属于策略还是实现,至少保证实现部分不会混入策略的相关代码。