访问者模式 | Visitor Pattern

来源:互联网 发布:aplusvable知乎 编辑:程序博客网 时间:2024/05/21 18:16

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

组成:
1.Visitor 抽象访问者角色,为该对象结构中具体元素角色声明一个访问操作接口。该操作接口的名字和参数标识了发送访问请求给具体访问者的具体元素角色,这样访问者就可以通过该元素角色的特定接口直接访问它。
2.ConcreteVisitor.具体访问者角色,实现Visitor声明的接口。
3.Element 定义一个接受访问操作(accept()),它以一个访问者(Visitor)作为参数。
4.ConcreteElement 具体元素,实现了抽象元素(Element)所定义的接受操作接口。
5.ObjectStructure 结构对象角色,这是使用访问者模式必备的角色。它具备以下特性:能枚举它的元素;可以提供一个高层接口以允许访问者访问它的元素;如有需要,可以设计成一个复合对象或者一个聚集(如一个列表或无序集合)。

定义一个元素的接口:

public interface ComputerPart {   public void accept(ComputerPartVisitor computerPartVisitor);}

扩展了元素接口的实体类:

public class Keyboard  implements ComputerPart {   @Override   public void accept(ComputerPartVisitor computerPartVisitor) {      computerPartVisitor.visit(this);   }}
public class Monitor  implements ComputerPart {   @Override   public void accept(ComputerPartVisitor computerPartVisitor) {      computerPartVisitor.visit(this);   }}
public class Mouse  implements ComputerPart {   @Override   public void accept(ComputerPartVisitor computerPartVisitor) {      computerPartVisitor.visit(this);   }}

创建结构对象角色:

public class Computer implements ComputerPart {   ComputerPart[] parts;   public Computer(){      parts = new ComputerPart[] {new Mouse(), new Keyboard(), new Monitor()};         }    @Override   public void accept(ComputerPartVisitor computerPartVisitor) {      for (int i = 0; i < parts.length; i++) {         parts[i].accept(computerPartVisitor);      }      computerPartVisitor.visit(this);   }}

定义一个访问者的接口:

public interface ComputerPartVisitor {    public void visit(Computer computer);    public void visit(Mouse mouse);    public void visit(Keyboard keyboard);    public void visit(Monitor monitor);}

实现了上述访问者接口的实体访问者:

public class ComputerPartDisplayVisitor implements ComputerPartVisitor {   @Override   public void visit(Computer computer) {      System.out.println("Displaying Computer.");   }   @Override   public void visit(Mouse mouse) {      System.out.println("Displaying Mouse.");   }   @Override   public void visit(Keyboard keyboard) {      System.out.println("Displaying Keyboard.");   }   @Override   public void visit(Monitor monitor) {      System.out.println("Displaying Monitor.");   }}

使用 ComputerPartDisplayVisitor 来显示 Computer 的组成部分:

public class VisitorPatternDemo {   public static void main(String[] args) {      ComputerPart computer = new Computer();      computer.accept(new ComputerPartDisplayVisitor());   }}

输出:

Displaying Mouse.Displaying Keyboard.Displaying Monitor.Displaying Computer.
原创粉丝点击