专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > 设计模式

设计中“接口膨胀”有关问题

发布时间: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文件中已损坏的pdf文件呢? ...

  • 关于Singleton模式继承的有关问题

    关于Singleton模式继承的问题? 定义一个Singleton类,一般都是要被其他实际的类继承,使这个实际的类具有Singleton功能。 现在看到二...

  • 怎么分析需求以决定用什么设计模式

    如何分析需求以决定用什么设计模式? 最近在看设计模式解析,基本上是陷到里面无法自拔了,我的问题是如何分析需求以决定用什么设计模...

  • 设计模式的应用解决方案

    设计模式的应用 我不知道什么时候该用什么样的设计模式 有号得例子或者教学视频吗 ------解决方案-------------------- 这个...

  • visio2002创建UML类图解决思路

    visio2002创建UML类图 使用visio2002画UML类图,文件-新建-选择绘图类型-UML模型图,就会报下面的错误 Runtime Error Program c:\.....

  • 蜂窝模式?该怎么解决

    蜂窝模式? 啥意思啊 ------解决方案-------------------- 是设计模式中的一个 161592169@qq.com 你给我发歌邮件 我回...

  • [HoWo03]是什么书,在google和百度上都找不到,该怎么解决

    [HoWo03]是什么书,在google和百度上都找不到 [HoWo03]是什么书,在google和百度上都找不到 ------解决方案-------------------- H...

热门推荐: