Design Patterns(二十四):Visite Pattern--VB代码

结构图

 

角色

  • 抽象访问者(Visitor)角色:声明了一个或多个访问操作,形成所有的具体元素角色必须的接口。
  • 具体访问者(ConcreteVisitor)角色:实现抽象访问者角色所声明的接口,也就是抽象访问者所声明的各个访问操作。 
  • 元素(Element)角色:定义一个接受操作,它以一个访问者为参数。 
  • 具体元素(ConcreteElement)角色:实现一个接受操作,它以一个访问者为参数。 
  • 对象结构(ObjectStructure)角色:可以提供一个高层接口以允许该访问者访问它的元素;可以是一个复合对象或集合对象。 

动机

  在软件构建过程中,由于需求的改变,某些类层次结构中常常需要增加新的行为(方法),如果直接在基类中做这样的更改,将会给予类带来很繁重的变更负担,甚至破坏原有设计。。
   如何在不更改类层次结构的前提下,在运行时根据需要透明地为类层次结构萨哈那个的各个类动态添加新的操作,从而避免上述问题?

意图
   表示一个作用于某对象结构中的各元素的操作。它可以在不改变各元素的类的前提下定义作用于这些元素的新的操作。

示意性代码

结构代码

一个实例

以下的例子演示了Employee对象集合允许被不同的Visitor(IncomeVisitor与VacationVisitor)访问其中的内容。

实例代码

Visitor Pattern模式的几个要点:
   1、Visitor模式通过所谓双重分发(double dispatch)来实现在不更改Element类层次结构的前提下,在运行时透明地为类层次结构上的各个类动态添加新的操作。
   2、所谓双重分发即Visitor模式中间包括了两个多态分发(注意其中的多态机制):第一个为accept方法的多态辨析;第二个为visit方法的多态辨析。
   3、Visitor模式的最大缺点在于扩展类层次结构(增添新的Element子类),会导致Visitor类的改变。因此Visitor模式适用于“Element类层次结构稳定,而其中的操作却经常面临频繁改动”。

我的理解

封装对象操作变化,支持在运行时为类层次结构动态添加新的操作。

参考资料
《C#面向对象设计模式纵横谈系列课程(24)》     李建中老师