设计模式-访问者模式

访问者模式是一种行为设计模式,它允许你在不修改现有对象结构的情况下,定义新的操作。访问者模式通过将操作封装在一个访问者对象中,使得可以在不同的对象上执行不同的操作,从而实现了操作和对象的解耦。

在Java中,访问者模式通常由两个主要的组件组成:元素(Element)和访问者(Visitor)。元素表示对象结构中的元素,访问者表示要对元素执行的操作。

以下是一个简单的Java代码示例,演示了访问者模式的使用:

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

// 具体元素A
class ConcreteElementA implements Element {
    @Override
    public void accept(Visitor visitor) {
        visitor.visit(this);
    }

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

// 具体元素B
class ConcreteElementB implements Element {
    @Override
    public void accept(Visitor visitor) {
        visitor.visit(this);
    }

    public void operationB() {
        System.out.println("ConcreteElementB: operationB");
    }
}

// 访问者接口
interface Visitor {
    void visit(ConcreteElementA elementA);
    void visit(ConcreteElementB elementB);
}

// 具体访问者
class ConcreteVisitor implements Visitor {
    @Override
    public void visit(ConcreteElementA elementA) {
        elementA.operationA();
    }

    @Override
    public void visit(ConcreteElementB elementB) {
        elementB.operationB();
    }
}

public class Main {
    public static void main(String[] args) {
        Element elementA = new ConcreteElementA();
        Element elementB = new ConcreteElementB();

        Visitor visitor = new ConcreteVisitor();

        elementA.accept(visitor);
        elementB.accept(visitor);
    }
}

在上面的示例中,我们定义了两个具体元素ConcreteElementA和ConcreteElementB,它们都实现了元素接口Element。我们还定义了一个具体访问者ConcreteVisitor,它实现了访问者接口Visitor。在Main类中,我们创建了具体元素的实例,并创建了具体访问者的实例。然后,我们调用元素的accept()方法,并将访问者作为参数传递进去,从而实现了对元素的操作。

访问者模式可以帮助我们在不修改现有对象结构的情况下,定义新的操作。它将操作封装在访问者对象中,使得可以在不同的对象上执行不同的操作,从而实现了操作和对象的解耦。这样,我们可以方便地添加新的操作,而无需修改现有的对象结构。

相关推荐
HelloWord~1 小时前
SpringSecurity+vue通用权限系统2
java·vue.js
让我上个超影吧1 小时前
黑马点评【基于redis实现共享session登录】
java·redis
liang_jy1 小时前
观察者模式
设计模式·面试
BillKu2 小时前
Java + Spring Boot + Mybatis 插入数据后,获取自增 id 的方法
java·tomcat·mybatis
全栈凯哥2 小时前
Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解
java·算法·leetcode·链表
chxii2 小时前
12.7Swing控件6 JList
java
全栈凯哥2 小时前
Java详解LeetCode 热题 100(27):LeetCode 21. 合并两个有序链表(Merge Two Sorted Lists)详解
java·算法·leetcode·链表
YuTaoShao2 小时前
Java八股文——集合「List篇」
java·开发语言·list
PypYCCcccCc2 小时前
支付系统架构图
java·网络·金融·系统架构
华科云商xiao徐2 小时前
Java HttpClient实现简单网络爬虫
java·爬虫