访问者模式

访问者模式

访问者模式

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

通过示例了解访问者模式

访问者模式(Visitor Pattern)是一种行为设计模式,它为对象结构提供一种方式,以独立于该结构的元素之外定义新操作。以下是一个简单的Java访问者模式示例,模拟一个简单的文件系统结构,其中访问者可以遍历并处理不同类型的文件:

首先,定义一个Element接口,代表文件系统中的元素:

public interface Element {
    void accept(Visitor visitor);
}

接着,创建具体的元素类,如Directory和File:

public class Directory implements Element {
    private String name;
    private List<Element> elements = new ArrayList<>();

    public Directory(String name) {
        this.name = name;
    }

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

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

    // getters, setters, etc.
}
public class File implements Element {
    private String name;

    public File(String name) {
        this.name = name;
    }

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

    // getters, setters, etc.
}

然后,定义一个Visitor接口,包含访问元素的方法:

public interface Visitor {
    void visit(Directory directory);
    void visit(File file);
}

创建具体的访问者类,比如BackupVisitor,用于备份文件:

public class BackupVisitor implements Visitor {
    private int backupCount = 0;

    @Override
    public void visit(Directory directory) {
        System.out.println("Backing up directory: " + directory.getName());
    }

    @Override
    public void visit(File file) {
        System.out.println("Backing up file: " + file.getName());
        backupCount++;
    }

    public int getBackupCount() {
        return backupCount;
    }
}

最后,使用访问者模式来遍历和处理文件系统:

public class VisitorPatternDemo {
    public static void main(String[] args) {
        Directory root = new Directory("root");
        Directory subdir1 = new Directory("subdir1");
        Directory subdir2 = new Directory("subdir2");
        File file1 = new File("file1.txt");
        File file2 = new File("file2.txt");
        File file3 = new File("file3.txt");

        root.add(subdir1);
        root.add(subdir2);
        subdir1.add(file1);
        subdir2.add(file2);
        subdir2.add(file3);

        BackupVisitor backupVisitor = new BackupVisitor();
        root.accept(backupVisitor);

        System.out.println("Number of files backed up: " + backupVisitor.getBackupCount());
    }
}

在这个例子中,访问者模式允许我们在不修改文件系统类(Directory和File)的基础上,添加新的操作(如备份)。BackupVisitor遍历文件系统,并对每个元素执行相应的操作。

  • 抽象

  • 封装

  • 继承

  • 多态

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
访问者模式是GOF设计模式中的一种行为型模式。它被描述为最复杂且最难以理解的一种模式。访问者模式的目的是封装一些作用于某种数据结构中的各元素的操作,可以在不改变这些元素的类的前提下定义这些操作。它通过将数据结构与操作分离,使得可以在不改变数据结构的前提下添加新的操作,提高了代码的灵活性和可扩展性。 访问者模式的构成包括元素(Element)、访问者(Visitor)和对象结构(Object Structure)。元素表示数据结构中的各个元素,它们通常会提供一个接受访问者的方法。访问者则表示对元素的操作,它们可以根据具体的元素类型进行不同的操作。对象结构则是一个容器,用于存放元素,并提供让访问者访问元素的接口。 访问者模式适用于数据结构相对稳定,但其操作经常发生变化的情况。它可以将操作的变化封装在访问者中,而无需改变元素的类。这样一来,当需要新增一种操作时,只需要新增一个访问者,而不需要改变元素的类。 访问者模式的优点包括增加新的操作非常方便,由于具体访问者类与具体元素类之间没有直接的关联,因此增加新的访问者类对原有类库无影响。同时,它也符合开闭原则,对于元素的类库可以在不修改源代码的情况下添加新的操作。 总结起来,访问者模式是一种通过将数据结构与操作分离的设计模式,可以在不改变数据结构的前提下添加新的操作。它的构成包括元素、访问者和对象结构,适用于数据结构相对稳定,但操作经常变化的情况。访问者模式的优点包括增加新的操作方便,符合开闭原则。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [详解设计模式:访问者模式](https://blog.csdn.net/weixin_45187434/article/details/128197861)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [设计模式 访问者模式](https://download.csdn.net/download/zjn640322/9685149)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值