分析模式 之 参与者(Party)

在我们分析模型的时候经常会遇到不同类型的事物在某些特性上有共同点,比如,人和公司,他们都有地址,电话,电子邮件等属性,在分析模型的时候,我们可能得出如下的模型:

看到上述的模型的时候,我们是否会觉得模型中的冗余呢?很显然,我们会想如何将这两者融合在一起呢,我们伟大的Martin Fowler同志提出了Party模式来描述此种类型的模型。我们用一种通用(父)的类型来定义人和公司,这样,只需要在模型中指定该通用类型和联系方式的关系即可,而人和公司则从属于该类类型。其模型如下:

 

在这个时候,大家停下来想一想,第二个模型为什么比第一个模型更好,难道只是模型没有冗余吗?很显然不是。考虑下面的情况,当一个应用中和联系方式相关的实体除了人和公司外,还有团队,子公司,部门等的时候,在第一种模型中,我们应该如何描述呢,很显然第一种模型将会变得很复杂且混乱。而第二种模型,我们可以很容易增加一种或多种和联系方式相关的实体,只是这些实体都是属于Party的。

从上面的例子我们可以看出,使用Party模式会使得类似的模型变得容易扩展。

回过头来我们再看看Party模式:

Problem:

问题是什么呢?问题是当有很多元素拥有相同的特性,或拥有相同责任的时候,我们应该如何去分析和描述它呢?

Solution:

解决方案是,定义一种通用的类型,这些拥有相同责任或特性的元素都从属于这种类型,我们只需要描述该通用类型的责任或特性即可,这里我们将这种通用类型称之为Party(参与者)



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1375229

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值