设计模式之访问者模式

作者 : admin 本文共1747个字,预计阅读时间需要5分钟 发布时间: 2024-06-9 共3人阅读

文章目录

  • 介绍
  • 示例代码
  • 示例代码地址

介绍

访问者模式(Visitor Pattern)是一种行为设计模式,它允许在不修改对象结构的前提下,为对象添加新的操作。这种模式将算法与数据结构分离,提供了对对象结构进行高层操作的方式,使得在不改变原有对象结构的情况下,可以对对象的行为进行扩展。
访问者模式的核心思想是定义一个访问者接口,这个接口规定了可以对哪些元素进行操作。然后,让结构中的每个元素都接受这个访问者,并实现一个接受(visit)方法,该方法接受访问者作为参数,调用访问者中的相应操作。这样,访问者就可以遍历整个对象结构并执行特定的操作。
主要角色

  • Element(元素): 具有接受访问者的方法,通常是接口或抽象类。
  • ConcreteElement(具体元素): 实现Element接口,具体实现被访问的逻辑。
  • Visitor(访问者): 定义了访问每个元素的接口,即visit方法。
  • ConcreteVisitor(具体访问者): 实现Visitor接口,为每个ConcreteElement提供具体的操作实现。
  • ObjectStructure(对象结构): 可以包含任何数量的元素,提供了遍历元素和接受访问者的方法。

示例代码

// 元素接口
interface Element {
void accept(Visitor visitor);
}
// 具体元素
class ConcreteElementA implements Element {
@Override
public void accept(Visitor visitor) {
visitor.visit(this);
}
}
class ConcreteElementB implements Element {
@Override
public void accept(Visitor visitor) {
visitor.visit(this);
}
}
// 访问者接口
interface Visitor {
void visit(ConcreteElementA element);
void visit(ConcreteElementB element);
}
// 具体访问者
class ConcreteVisitor implements Visitor {
@Override
public void visit(ConcreteElementA element) {
System.out.println("ConcreteElementA is visited.");
}
@Override
public void visit(ConcreteElementB element) {
System.out.println("ConcreteElementB is visited.");
}
}
// 对象结构(这里简化为一个简单的数组)
class ObjectStructure {
private List<Element> elements = new ArrayList<>();
public void attach(Element element) {
elements.add(element);
}
public void accept(Visitor visitor) {
for (Element element : elements) {
element.accept(visitor);
}
}
}
// 示例
public class VisitorPatternDemo {
public static void main(String[] args) {
ObjectStructure objectStructure = new ObjectStructure();
objectStructure.attach(new ConcreteElementA());
objectStructure.attach(new ConcreteElementB());
Visitor visitor = new ConcreteVisitor();
objectStructure.accept(visitor);
}
}

示例代码地址

http://gitee.com/youxiaxiaomage/java-practices/tree/master/yxxmg-gof-sample/src/main/java/com/yxxmg/gof/behavior/visitor

本站无任何商业行为
个人在线分享 » 设计模式之访问者模式
E-->