博客
关于我
二十三种设计模式(第十五种)-----访问者模式(Visitor)
阅读量:507 次
发布时间:2019-03-07

本文共 2622 字,大约阅读时间需要 8 分钟。

访问者模式(Visitor) - 设计模式实践

模式概述

访问者模式是一种设计模式,旨在封装一些作用于某些数据结构中的各元素的操作。其核心思想是在不改变数据结构的情况下,为这些元素定义新的操作。这种模式能够将数据结构与数据操作分离,从而解决数据结构与操作的耦合性问题。

访问者模式的主要应用场景是:当需要对一个对象结构中的对象执行多种不同操作(这些操作彼此无关)时,且希望避免让这些操作"污染"对象的类。通过访问者模式,可以实现对这些操作的封装和扩展。

类图解析

访问者模式的核心类图包括以下几个关键角色:

  • Visitor:抽象访问者类,声明对具体元素的访问操作。
  • ConcreteVisitor:具体访问者类,实现 Visitor 中声明的操作。
  • ObjectStructure:对象结构类,负责管理和枚举对象结构中的元素。
  • Element:元素抽象类,定义一个 accept 方法接收访问者。
  • ConcreteElement:具体元素类,实现 accept 方法。
  • 通过这种方式,访问者模式实现了对数据操作的统一管理和扩展。

    实际应用场景

    以下是一个实际应用的示例:

    假设我们有一个 Person 类和其子类 ManWoman。每个子类都有一个方法 accept,用于接收一个操作对象。我们定义了一个抽象操作类 Action,其中包含两个抽象方法:getManResultgetWomanResult,用于分别处理男性和女性的测评结果。

    通过访问者模式,我们可以轻松地增加新的操作类型(如成功、失败等)而不需要修改现有的类结构。具体实现如下:

    // 定义抽象操作类public abstract class Action {    public abstract void getManResult(Man man);    public abstract void getWomanResult(Woman man);}// 定义抽象人类public abstract class Person {    public abstract void accept(Action action);}// 实现具体人类public class Man extends Person {    @Override    public void accept(Action action) {        action.getManResult(this);    }}public class Woman extends Person {    @Override    public void accept(Action action) {        action.getWomanResult(this);    }}// 实现具体的操作类(如成功、失败)public class Success extends Action {    @Override    public void getManResult(Man man) {        System.out.println("男人给的评价是成功");    }    @Override    public void getWomanResult(Woman man) {        System.out.println("女人给的评价是成功");    }}public class Fail extends Action {    @Override    public void getManResult(Man man) {        System.out.println("男人给的评价是失败");    }    @Override    public void getWomanResult(Woman man) {        System.out.println("女人给的评价是失败");    }}// 定义对象结构管理类public class ObjectStructure {    private List
    persons = new LinkedList<>(); public void attach(Person p) { persons.add(p); } public void detach(Person p) { persons.remove(p); } public void display(Action action) { for (Person person : persons) { person.accept(action); } }}// 客户端主程序public static void main(String[] args) { ObjectStructure objectStructure = new ObjectStructure(); objectStructure.attach(new Man()); objectStructure.attach(new Woman()); // 测试成功操作 Success success = new Success(); objectStructure.display(success); System.out.println("==================="); // 测试失败操作 Fail fail = new Fail(); objectStructure.display(fail);}

    双分派机制

    在上述实现中,双分派机制得到了很好的体现。双分派意味着不管操作的类型如何,系统都能正确地找到对应的方法进行执行。这意味着我们可以轻松地添加新的操作类型(如 Wait),而无需修改现有的类结构。只需定义一个新的 Action 子类,并在客户端进行调用即可。

    这种设计方式的优势在于,既保持了系统的灵活性,又避免了类之间的紧耦合,使得系统更容易进行扩展和维护。

    如果需要进一步了解访问者模式,可以参考相关技术文档或教学资源。

    转载地址:http://hlbcz.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现BreadthFirstSearch广度优先搜索算法(附完整源码)
    查看>>
    Objective-C实现bubble sort冒泡排序算法(附完整源码)
    查看>>
    Objective-C实现Burke 抖动算法(附完整源码)
    查看>>
    Objective-C实现CaesarsCiphe凯撒密码算法(附完整源码)
    查看>>
    Objective-C实现cartesianProduct笛卡尔乘积算法(附完整源码)
    查看>>
    Objective-C实现check strong password检查密码强度算法(附完整源码)
    查看>>
    Objective-C实现chudnovsky algorithm楚德诺夫斯基算法(附完整源码)
    查看>>
    Objective-C实现circle sort圆形排序算法(附完整源码)
    查看>>
    Objective-C实现cocktail shaker sort鸡尾酒排序算法(附完整源码)
    查看>>
    Objective-C实现cocktailShakerSort鸡尾酒排序算法(附完整源码)
    查看>>
    Objective-C实现combine Without Repetitions不重复地结合算法(附完整源码)
    查看>>
    Objective-C实现conjugate gradient共轭梯度算法(附完整源码)
    查看>>
    Objective-C实现coulombs law库仑定律算法(附完整源码)
    查看>>
    Objective-C实现currency converter货币换算算法(附完整源码)
    查看>>
    Objective-C实现data transformations数据转换算法(附完整源码)
    查看>>
    Objective-C实现DBSCAN聚类算法(附完整源码)
    查看>>
    Objective-C实现DBSCAN聚类算法(附完整源码)
    查看>>
    Objective-C实现degreeToRadian度到弧度算法(附完整源码)
    查看>>
    Objective-C实现depth first search深度优先搜索算法(附完整源码)
    查看>>
    Objective-C实现des文件加密算法(附完整源码)
    查看>>