访问者模式(Visitor):表示一个作用于某对象结构中的各个元素的操作。它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。
发访问者模式结构图如下:
访问者模式代码模板:
//Visitor类,为该对象结构中ConcreteElement的每一个类声明一个Visit操作。
class Visitor
{
public:
void VisitConcreteElementA(ConcreteElementA concreteElementA );
void VisitConcreteElementB(ConcreteElementB concreteElementB );
};
//ConcreteVisitor1和ConcreteVisitor2类,具体访问者,实现每个由Visitor声明的操作。每个操作实现算法的一部分,而该算法片段乃是对应于结构中对象的类。
class ConcreteVisitor1:public Visitor
{
public:
void VisitConcreteElementA(ConcreteElementA concreteElementA)
{
cout<<"ConcreteElementA被访问";
}
void VisitConcreteElementB(ConcreteElementB concreteElementB)
{
cout<<"ConcreteElementB被访问";
}
};
class ConcreteVisitor2:public Visitor
{
public:
void VisitConcreteElementA(ConcreteElementA concreteElementA)
{
cout<<"ConcreteElementA被访问";
}
void VisitConcreteElementB(ConcreteElementB concreteElementB)
{
cout<<"ConcreteElementB被访问";
}
};
//Element类,定义一个Accept操作,它以一个访问者为参数
class Element
{
public:
void Accept(Visitor visitor);
};
//ConcreteElementA和ConcreteElementB类,具体元素,实现Accept操作。
class ConcreteElementA:public Element
{
public:
void Accept(Visitor visitor)
{
visitor.VisitConcreteElementA(this);
}
void OperationA(){}//其他的相关方法
};
class ConcreteElementB:public Element
{
public:
void Accept(Visitor visitor)
{
visitor.VisitConcreteElementB(this);
}
void OperationB(){}//其他的相关方法
};
//ObjectStructure类,能枚举它的元素,可以提供一个高层的接口以允许访问者访问它的元素
class ObjectStructure
{
private:
List<Element> elements = new List<Element>();
public:
void Attach(Element element)
{
elements.Add(element);
}
void Detach(Element element)
{
elsments.Remove(element);
}
void Accept(Visitor visitor)
{
foreach(Element e in elements)
{
e.Accept(visitor);
}
}
};
//客户端代码
void main()
{
ObjectStructure 0 = new ObjectStructure();
o.Attach(new ConcreteElementA());
o.Attach(new ConcreteElementB());
ConcreteVisitor1 v1 = new ConcreteVisitor1();
ConcreteVisitor2 v2 = new ConcreteVisitor2();
o.Accept(v1);
o.Accept(v2);
}
访问者模式过于复杂,大多数时候使用不到。访问者目的是要把处理数据从结构分离猪来,实现数据结构和作用于结构上的操作之间解耦,使得操作集合可以相对自由地演化。如果系统有比较稳定的数据结构,又又易于变化的算法的话,使用访问者模式就是比较合适的,因为访问者模式使得算法操作的增加变得容易。
访问者模式优点:
增加新的操作很容易,因为增加新的操作就意味着增加一个新的访问者。访问者模式将有关的行为集中到一个访问者对象中。
访问者模式缺点:
使增加新的数据结构变得困难。