描述
访问者模式把数据结构和作用于结构上的操作解耦合,使得操作集合可相对自由地演化
思想
访问者模式就是一种分离对象数据结构与行为的方法,通过这种分离,可达到为一个被访问者动态添加新的操作而无需做其它的修改的效果
与适配器模式的不同在于:
访问者模式不持有类实例对象,其实就是用类A的类方法对指定类C实例对象的方法进行了封装,入参为类C的实例对象;
这样可以动态的传递类C实例对象调用C的方法;
适用
访问者模式适用于数据结构相对稳定算法又易变化的系统;
适用场景:如果我们想为一个现有的类增加新功能,不得不考虑几个事情:
- 新功能会不会与现有功能出现兼容性问题?
- 以后会不会再需要添加?
- 如果类不允许修改代码怎么办?
面对这些问题,最好的解决方法就是使用访问者模式,访问者模式适用于数据结构相对稳定的系统,把数据结构和算法解耦,
问题
增加新的数据结构很困难
其他
访问者模式使得算法操作增加变得容易。若系统数据结构对象易于变化,经常有新的数据对象增加进来,则不适合使用访问者模式。优点:增加操作很容易,因为增加操作意味着增加新的访问者。访问者模式将有关行为集中到一个访问者对象中,其改变不影响系统数据结构。
UML

示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
| interface Visitor{ public void visit(Subject sub); } class MyVisitor implements Visitor{ @Override public void visit(Subject sub){ Test.printMsg("visit the subject "+sub.getSubject()); } } interface Subject { public void accept(Visitor visitor); public String getSubject(); } class MySubject implements Subject { @Override public void accept(Visitor visitor) { visitor.visit(this); } @Override public String getSubject() { return "Mysubject"; } }
public class Test { public static void printMsg(String msg){ System.out.println(msg); } public static void main(String[] args){ Visitor visitor = new MyVisitor(); Subject sub = new MySubject(); sub.accept(visitor); } }
|