设计模式初学者系列—重构到Bridge模式

发表于:2010-03-09来源:作者:点击数: 标签:重构设计Bridge初学者模式
设计模式初学者系列—重构到Bridge模式 软件测试 在这篇文章中,我将以记述我整个重构过程的方式来得到桥接模式,也许很多人学习设计模式都有我这样的历程,看过很多模式的书籍,但还是无从下手,很多人都说模式往往是重构得来的,但是如何重构?如何去思考?

  设计模式初学者系列—重构到Bridge模式   软件测试 

     在这篇文章中,我将以记述我整个重构过程的方式来得到桥接模式,也许很多人学习设计模式都有我这样的历程,看过很多模式的书籍,但还是无从下手,很多人都说模式往往是重构得来的,但是如何重构?如何去思考?

  在这个设计模式初学者系列里我将改变以前的风格,今后每一篇都以真实的项目重构例子来描述重构到模式,所有的描述都来源于现实,如果没有现实的案例那我宁愿不写。希望以这种方式记录能够给一些像我一样曾经很困惑的朋友帮助。

  背景

  PM:小Y,你看,这个Dundas的Chart(注1)控件效果很好,功能也很强大,但是使用的时候太麻烦了,你能不能将其封装一下,这样其他人使用的时候也简单多了

  我:嗯,这个我看看吧,应该可以。

  注1

  Dundas Chart控件是一个既可以用在WinForm里又可以用在WebForm里的图表控件,可以绘制各种曲线图、柱状图和饼图等等,功能十分强大。在本文中我们要了解Dundas Chart的三个概念:Chart、ChartArea、Series

  如是我拿起纸和笔去收集需求

  A:这个我觉得当这个控件上的一个Series的Enabled属性值变化的时候应该触发一个事件,这样我们就可以在这个事件触发时干些事情了,但是现在没有,我不得不做很多工作

  B:和A一样的问题,我觉得控件上一个ChartArea的Visible属性值变化时也应该触发一个事件。

  C: ………

  我的头慢慢的大起来,需求收集了一大堆,怎么弄呢?我还是做了下面这样的个设计

  第一次重构:使用继承封装Chart原生API,使其更好使用

  我相信很多人第一个设计也许是这样,一下子就想到继承,这样我们可以复用Dundas Chart里面的很多东西了,以免重写很多东西。

  下面只选取一段Code:

  public class JurassicSeries : Series

  {

  //...更多扩展

  public event EventHandler SeriesEnabled;

  protected void OnSeriesEnabled()

  {

  if (SeriesEnabled != null)

  SeriesEnabled(this, new EventArgs());

原文转自:http://www.ltesting.net