Java设计模式指南针

2017-11-07  本文已影响46人  Terry

什么是设计模式

小说家和剧本作家很少从头开始设计剧情。他们总是沿袭一些业已存在的模式像“悲剧性英雄”模式(《哈姆雷特》)或浪漫小说。同样的,软件开发人员也沿袭一些模式来解决软件开发过程当中一些重复发生的问题。
每一个模式描述了一个在我们周围不断重复发生的问题,以及该问题的解决方案的核心。这样你就能一次又一次使用用该方案而不必做重复劳动。在面向对象的解决方案里,我们用对象和接口来解决发生在软件设计中的问题。
一般而言,一个模式有四个基本要素:

模式四个基本要素

其实,不同的出发点会产生对什么是设计模式和什么不是模式的理解不同。一个人的模式对另一个人来说可能只是基本构造部件。所以对于我们程序员来说,我们是在一定的抽象层次上讨论模式。

设计模式的目的

你曾经有多少次有过这种感觉——你已经解决过了一个问题但就是不能确切的知道是在什么地方或怎么解决的?如果你能记起以前问题的细节和怎么解决的,你就可以复用以前的经验而不需要重新发现它。那么其实我们使用设计模式最大的目的就是复用。其他的好处等我们下面在具体使用的时候再一一介绍。

设计模式的分类

设计模式在粒度和抽象层次上各不相同。由于存在众多的设计模式,我们用按照设计模式的结构来进行一个划分:


image.png

怎样选择设计模式?

JAVA设计模式大致有21个可供我们选择,要从这里面挑出一个针对特定问题的设计模式还是很困难的,尤其是面对一组新的模式,你还不熟悉他的时候。这里给出几个方法帮助你们发现适合你手头问题的设计模式:

如何使用设计模式?

其实前面的理解这些设计模式并没有什么难度,难就难在我们怎样去应用设计模式来解决问题。设计模式的使用流程不是一成不变,只有哪个更合适,更加贴合你的应用场景。下面给出一些惯例:

这里摘自《Design Pattern》,就不详细写了

  1. 大致浏览一遍模式 特别注意其适用性部分和效果部分。
  2. 回头研究结构部分、参与者部分和协作部分。确保你理解这个模式的类和对象以及它们是怎么样关联的。
  3. 看示例代码部分,看这个模式代码形成的具体例子。
  4. 选择模式参与者的名字,使他们在上下文中有意义。
  5. 定义类
  6. 定义模式中专用于应用的操作名称。
  7. 实现执行模式中责任和协作的操作。

大体的流程基本是这样,只是书中的介绍更加细分。其实关键的一个核心点在于抽象,如何去找合适的对象,这个对象的确定,直接决定了我们能否准确的套用设计模式,这在某种程度上实际上考验了我们对数据的抽象能力。所谓抽象就是从表面看到本质,从片面看到整体,然后抽丝剥茧似的找出那些稳定的、共同的特征。
下面将在下面文章中逐步介绍每个设计模式具体怎么使用。

上一篇下一篇

猜你喜欢

热点阅读