03-JAVA设计模式-访问者模式

访问者模式

什么是访问者模式

访问者模式(Visitor Pattern)是软件设计模式中的一种行为模式,它用于将数据结构中的元素与操作这些元素的操作解耦。这种模式使得可以在不修改数据结构的情况下添加新的操作。

在访问者模式中,我们定义了两个主要角色:

  • 访问者(Visitor): 这个接口声明了一个访问元素的方法,这个方法的名字和参数表示了访问操作。
  • 元素(Element): 这是一个定义了接受访问者(accept)方法的接口。这个方法的名字和参数表示了被访问的操作。
  • 具体元素(ConcreteElement): 实现元素接口,并存储数据。同时,它实现接受操作,通常是通过调用访问者的访问方法。
  • 具体访问者(ConcreteVisitor): 实现访问者接口,并定义了对特定元素的访问操作。
  • 对象结构(Object Structure): 通常包含元素的集合,并提供一个方法,使得访问者可以访问其元素。

常见应用场景:

  • XML文档解析器设计
  • 编译器的设计
  • 复杂集合对象的处理

访问者模式表示一个作用于某对象结构中的各个元素的操作,他是我们可以在不改变各个元素的类的前提下定义作用域这些元素的新操作。

实际开发中应用范围非常窄。

示例

Element.java

java 复制代码
// 元素接口
public interface Element {
    void accept(Visitor visitor);
}

Visitor.java

java 复制代码
// 访问者接口
public interface Visitor {
    void visit(ConcreteElementA elementA);

    void visit(ConcreteElementB elementB);
}

ConcreteElementA.java

java 复制代码
// 具体元素A
public class ConcreteElementA implements Element {

    @Override
    public void accept(Visitor visitor) {
        visitor.visit(this);
    }

    public void operationA() {
        System.out.println("Element A: operationA()");
    }

}

ConcreteElementB.java

java 复制代码
// 具体元素B
public class ConcreteElementB implements Element {

    @Override
    public void accept(Visitor visitor) {
        visitor.visit(this);
    }
    public void operationB() {
        System.out.println("Element B: operationB()");
    }
}

ConcreteVisitor.java

java 复制代码
// 具体访问者
public class ConcreteVisitor  implements Visitor {
    @Override
    public void visit(ConcreteElementA elementA) {
        elementA.operationA();
        System.out.println("Visited Element A");
    }

    @Override
    public void visit(ConcreteElementB elementB) {
        elementB.operationB();
        System.out.println("Visited Element B");
    }
}

ObjectStructure.java

java 复制代码
import java.util.ArrayList;
import java.util.List;

// 对象结构
public class ObjectStructure {
    private List<Element> elements = new ArrayList<>();

    public void attach(Element element) {
        elements.add(element);
    }

    public void detach(Element element) {
        elements.remove(element);
    }

    public void accept(Visitor visitor) {
        for (Element element : elements) {
            element.accept(visitor);
        }
    }
}

TestClient.java

java 复制代码
// 测试
public class TestClient {
    public static void main(String[] args) {
        ObjectStructure objectStructure = new ObjectStructure();
        objectStructure.attach(new ConcreteElementA());
        objectStructure.attach(new ConcreteElementB());

        ConcreteVisitor visitor = new ConcreteVisitor();
        objectStructure.accept(visitor);
    }
}

执行结果:

gitee源码

git clone https://gitee.com/dchh/JavaStudyWorkSpaces.git

相关推荐
roman_日积跬步-终至千里6 分钟前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
野犬寒鸦28 分钟前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
wenzhangli728 分钟前
ooderA2UI BridgeCode 深度解析:从设计原理到 Trae Solo Skill 实践
java·开发语言·人工智能·开源
HalvmånEver31 分钟前
Linux:线程互斥
java·linux·运维
rainbow688938 分钟前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法
灵感菇_42 分钟前
Java 锁机制全面解析
java·开发语言
indexsunny42 分钟前
互联网大厂Java面试实战:Spring Boot微服务在电商场景中的应用与挑战
java·spring boot·redis·微服务·kafka·spring security·电商
娇娇乔木1 小时前
模块十一--接口/抽象方法/多态--尚硅谷Javase笔记总结
java·开发语言
saber_andlibert1 小时前
TCMalloc底层实现
java·前端·网络
wangjialelele1 小时前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先