软件架构基本技法——策略和实现分离

是什么

模块可以承载策略或实现。但是,一个模块不可以同事承载二者。

  • 策略模块

策略模块依赖于软件的前提条件,这类模块通常用于给业务逻辑或其他模块选择参数。

  • 实现模块

实现模块不依赖于软件的前提条件,这类模块通常是独立的逻辑部分。软件的前提条件会作为传递给模块的参数给出。

为什么

实现模块不依赖于特定的软件,是一种纯粹的模块,因此可供其他软件重复使用。

而策略模块是为了特定软件量身打造的。当软件发生变动时,策略模块也要被迫发生改变。因此如果将实现和策略混在一起,那么当策略发生变动时,实现也会受到牵连,影响模块的重复使用。

怎么做

设计时要有意识地区分依赖于软件前提条件的策略部分和不依赖于软件前提条件的实现部分,然后将二者分别写入不同的模块。

当遇到无法分离的情况时,至少要在模块内部明确区分策略部分和实现部分。

另外,即便最初分离了策略与实现,在维护代码的过程中二者也可能会重新混在一起。因此在开展修改工作之前,要明确修改对象到底属于策略还是实现,至少保证实现部分不会混入策略的相关代码。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值