访问者模式

定义

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

类图

  1. Visitor
    • 为该对象结构中ConcreteElement的每一个类声明一个Visit操作。该操作的名字和特征标识了发送visit请求给该访问者的那个类。这使得访问者可以确定正被访问元素的具体的类。这样访问者就可以通过该元素的特定接口直接访问它
  2. ConcreteVisitor
    • 实现每个由Visitor声明的操作。每个操作实现本算法的一部分,而该算法片断乃是对应于结构中对象的类。ConcreteVisitor为该算法提供上下文并存储它的局部状态。这一状态常常在遍历该结构的过程中累积结果
  3. Element
    • 定义一个Accept操作,它以一个访问者为参数
  4. ConcreteElement
    • 实现Accept操作,它以一个访问者为参数
  5. ObjectStructure
    • 能枚举它的元素
    • 可以提供一个高层的接口以允许该访问者访问它的元素
    • 可以使一个复合

使用场景

一个对象结构包含很多类对象,它们有不同的接口,而你想对这些对象实施一些依赖于其具体类的操作。

  1. 需要对一个对象结构中的对象进行很多不同的并且不相关的操作,而你想避免让这些操 作”污染”这些对象的类。Visitor使得你可以将相关的操作集中起来定义在一个类中。 当该对象结构被很多应用共享时,用Visitor模式让每个应用仅包含需要用到的操作。
  2. 定义对象结构的类很少改变,但经常需要在此结构上定义新的操作。改变对象结构类需要重定义对所有访问者的接口,这可能需要很大的代价。如果对象结构类经常改变,那么可能还是在这些类中定义这些操作较好。

效果

  1. 访问者模式使得易于增加新的操作
  2. 访问者集中相关的操作而分离无关的操作
  3. 增加新的ConcreteElement类很困难
  4. 通过类层次进行访问
  5. 累积状态
  6. 破坏封装

wikipedia