设计中“接口膨胀”有关问题
发布时间:2011-06-19 13:22:47 文章来源:www.iduyao.cn 采编人员:星星草
设计中“接口膨胀”问题
不知道大家在设计中是否有碰到下面这种情况:
我有4个功能和概念上独立的模块,分别是:M1,M2,M31,M32
它们的关系是:M1-->M2(M1聚合M2),M2-->M31,M32(M2聚合M31,M32)
即:M1-->M2-->M3,M4
一个用户可能实例化一个M1,M2实例M2,M2实例M3,M4
多个用户的话会有多条这样的实例过程
我现在的问题是:M3中需要输入一个参数A,那我现在会想到的是M3的参数需要由
M2来输入,那这样M2便需要一个输入参数A,M2的输入又需要由
M1来提供。如果同样我在M4中也需要一个参数B的话,那最终也
会到M1这里来提供接口输入。随着我的模块或聚合层数的增加
那M1这里会需要提供指数级的接口。不知道有没有更好的方法来
解决这样的 问题呢???
------解决方案--------------------
可以把底层的接口暴露出来,比如在M1中添加这样一个方法:
class M1
{
public:
M2* GetM2();
};
好处是底层模块接口变动时不必一连串的修改上层模块接口(纯体力活),也不必把底层接口挨个的封装一遍(也是纯体力活)
缺点是调用起来挺麻烦的,类似下面的样子:
M2* m2 = m1->GetM2();
M3* m3 = m2->GetM3();
m3->SetParam(param);
------解决方案--------------------
这么设计不对,这不应该是接口膨胀问题。
接口应该是是一个软件元素外部可见的,同时也描述了这个软件元素的责任。
很难想象M1需要暴露出M4个一个设置参数的接口。
你提到了聚合,在M1在使用对象代理(object delegate) 来复用功能的模式下,
M1提供的接口不会受到内部对象的影响,仅仅由M1本身的职责决定。
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。
其他相似内容:
-
关于后台服务器架构问题
最近小弟在优化后台服务器的工作,因为以前的服务器是采用单进程,单线程,并没有涉及到多台服务器的交互问题...
-
请教个模式的应用
要做个公司的权限管理,有三个角色
公司管理员,具有权限M1(a),M1(a,b)
部门经理,具有权限M1(a,b),M2()
部门管理...
-
继承的优缺点
请问大家如何理解继承,如何使用好继承?
------解决方案--------------------
关于这个问题,我的确做了一些思考,推荐...
-
急!急!急!设计程序删除文件夹中的已损坏pdf文件
文件夹中总共的pdf文件数量有三十几万,怎么才能删除这些pdf文件中已损坏的pdf文件呢?
...
-
关于Singleton模式继承的问题?
定义一个Singleton类,一般都是要被其他实际的类继承,使这个实际的类具有Singleton功能。
现在看到二...
-
如何分析需求以决定用什么设计模式?
最近在看设计模式解析,基本上是陷到里面无法自拔了,我的问题是如何分析需求以决定用什么设计模...
-
设计模式的应用
我不知道什么时候该用什么样的设计模式
有号得例子或者教学视频吗
------解决方案--------------------
这个...
-
visio2002创建UML类图
使用visio2002画UML类图,文件-新建-选择绘图类型-UML模型图,就会报下面的错误
Runtime Error
Program c:\.....
-
蜂窝模式?
啥意思啊
------解决方案--------------------
是设计模式中的一个
161592169@qq.com
你给我发歌邮件
我回...
-
[HoWo03]是什么书,在google和百度上都找不到
[HoWo03]是什么书,在google和百度上都找不到
------解决方案--------------------
H...