1.1 背景
目前的XXXX扩展接口定义如下:
class ProductProcesser
{
public:
virtual long process(const in_type&,out_type&) = 0;
…. //还有其他扩展接口也定义在一起
}
讨论集中在上面process成员函数的定义。因为产品需求的变化,目前的process函数需要在两种情况下调用,因此考虑两种修改方案:
1)修改process为:long (int flag,const in_type&,out_type&)
flag代表不同应用场合
2)定义不同名字的虚函数
3)修改process为long process(int flag,void* in_pData,void* out_pdata) = 0;这种方式意图是支持不同处理参数
我们都希望这次改动之后系统的可扩展性更好
1.3 分析
首先说明,每种设计方案都有自己的优缺点,不存在一个最好的方案。只能依据软件设计的一些基本原则来分析一个设计是否有改善的余地,
1. 看接口类ProductProcess的定义,因为包含多种处理业务的扩展接口,这些扩展接口之间基本上没有关系,是松散耦合的,很显然违背了ISP(接口分离原则)。

本文探讨了一种通用接口设计方案,旨在提高系统的可扩展性。通过对现有接口的分析,提出了违反ISP(接口分离原则)和OCP(开放封闭原则)的问题。作者提出了一种退化接口类型的实现方式,使用接口继承和职责链模式,解决了参数个数和类型不固定的问题。此外,通过Visitor模式和getProtocol方法确保平台对接口的控制,防止二次开发人员的误操作。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



