成长的烦恼:初涉设计模式[2]

发表于:2010-03-01来源:作者:点击数: 标签:设计初涉烦恼成长模式
成长的烦恼:初涉设计模式[2] 软件测试 CSort *pSort = new CBubbleSort; CClient.ListSort(pSort); 如果要改成快速排序,只要如此: CSort *pSort = new CQ uickSort; CClient.ListSort(pSort); 测试交差,当然经理自己也有想法,又让小王试了另外的几个算

  成长的烦恼:初涉设计模式[2]  软件测试

  CSort *pSort = new CBubbleSort;

  CClient.ListSort(pSort);

  如果要改成快速排序,只要如此:

  CSort *pSort = new CQuickSort;

  CClient.ListSort(pSort);

  测试交差,当然经理自己也有想法,又让小王试了另外的几个算法,小王都能轻松的完成。策略模式的作用在这里淋漓尽致的发挥了,小王心里特别有成就感。

  过了些日子,客户提出需要按文件名、日期进行排序,小王觉得这还是比较简单的,更改了一下UML图:

  改代码的主要工作是copy-paste,就四个函数,也就很快完成了。

  客户的需求是不会停止的,为了加强功能,提出需要按文件大小、文件的类型排序,天知道客户还会提出什么要求。

  “再也不能这样活”,小王听着歌,陷入了沉思。

  “排序的算法和比较算法分开来会如何呢?把它们脱耦,使得二者可以独立地变化。这句话怎么这么熟悉,我肯定在哪里看到过。”小王忙翻开《设计模式》,开始查阅。

  “Got it,这不就是桥梁模式(Bridge)。”一阵欣喜,马上就干。半个小时后,UML图出来了,如下:

  客户端代码如下:

  CSort *pSort = new CQuickSort;

  CCompareType *pType = new CNameCompare;

  pSort->SetType(pType);

  pSort->Sort(pList);

  哈哈,客户们,你们尽管提要求吧。

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