visitor设计模式ppt_常用的设计模式

visitor设计模式ppt_常用的设计模式动机Visitor是访问者的意思。数据结构中保存着元素。一般我们需要对元素进行处理,那么处理元素的代码放在哪里呢?最显然的方法就是放在数据结构的类中,在类中添加处理的方法。但是如果有很多处理,就比较麻烦了,每当增加一种处理,我们就不得不去修改表示数据结构的类。visitor模式就是用来解决这个问题的,visitor模式将数据结构的定义和处理分离开。也就是会新增一个访问者的类,将数据元素的处理交给访问者类,这样以后要新增处理的时候,只需要新增访问者就可以了。模式定义将更新(变更)封装到一个类中(访问

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

动机

Visitor是访问者的意思。
数据结构中保存着元素。一般我们需要对元素进行处理,那么处理元素的代码放在哪里呢?最显然的方法就是放在数据结构的类中,在类中添加处理的方法。但是如果有很多处理,就比较麻烦了,每当增加一种处理,我们就不得不去修改表示数据结构的类。
visitor模式就是用来解决这个问题的,visitor模式将数据结构的定义和处理分离开。也就是会新增一个访问者的类,将数据元素的处理交给访问者类,这样以后要新增处理的时候,只需要新增访问者就可以了。

模式定义

将更新(变更)封装到一个类中(访问操作),并由待更改类提供一个接收接口,则可达到效果。

实例

//visit.h
 
#ifndef VISITOR_H
#define VISITOR_H
 
#include <iostream>
#include <string>
#include <vector>
 
class Element;
class CPU;
class VideoCard;
class MainBoard;
 
/*------------------*/
class Visitor { 
   
public:
    Visitor(std::string name) { 
   
        visitorName = name;
    }
    virtual void visitCPU( CPU* cpu ) { 
   };
    virtual void visitVideoCard( VideoCard* videoCard ) { 
   };
    virtual void visitMainBoard( MainBoard* mainBoard ) { 
   };
 
 
    std::string getName() { 
   
        return this->visitorName;
    };
private:
    std::string visitorName;
};
 
 
class Element { 
   
public:
    Element( std::string name ) { 
   
        eleName = name;
    }
    virtual void accept( Visitor* visitor ) { 
   };
 
    virtual std::string getName() { 
   
        return this->eleName;
    }
private:
    std::string eleName;
};
 
/*----------- Elements -------------*/
 
class CPU : public Element { 
   
public:
    CPU(std::string name) : Element(name) { 
   }
 
    void accept(Visitor* visitor) { 
   
        visitor->visitCPU(this);
    }
};
 
class VideoCard : public Element { 
   
public:
    VideoCard(std::string name) : Element(name) { 
   }
 
    void accept(Visitor* visitor) { 
   
        visitor->visitVideoCard(this);
    }
};
 
class MainBoard : public Element { 
   
public:
    MainBoard(std::string name) : Element(name) { 
   }
      
    void accept(Visitor* visitor) { 
   
        visitor->visitMainBoard(this);
    }
};
 
/*----------- ConcreteVisitor -------------*/
 
class CircuitDetector : public Visitor { 
   
public:
    CircuitDetector(std::string name) : Visitor(name) { 
   }
 
    // checking cpu
    void visitCPU( CPU* cpu ) { 
   
        std::cout << Visitor::getName() << " is checking CPU's circuits.(" << cpu->getName()<<")" << std::endl;
    }
 
    // checking videoCard
    void visitVideoCard( VideoCard* videoCard ) { 
   
        std::cout << Visitor::getName() << " is checking VideoCard's circuits.(" << videoCard->getName()<<")" << std::endl;
    }
 
    // checking mainboard
    void visitMainBoard( MainBoard* mainboard ) { 
   
        std::cout << Visitor::getName() << " is checking MainBoard's circuits.(" << mainboard->getName() <<")" << std::endl;
    }
 
};
 
class FunctionDetector : public Visitor { 
   
public:
    FunctionDetector(std::string name) : Visitor(name) { 
   }
    virtual void visitCPU( CPU* cpu ) { 
   
        std::cout << Visitor::getName() << " is check CPU's function.(" << cpu->getName() << ")"<< std::endl;
    }
 
    // checking videoCard
    void visitVideoCard( VideoCard* videoCard ) { 
   
        std::cout << Visitor::getName() << " is checking VideoCard's function.(" << videoCard->getName()<< ")" << std::endl;
    }
 
    // checking mainboard
    void visitMainBoard( MainBoard* mainboard ) { 
   
        std::cout << Visitor::getName() << " is checking MainBoard's function.(" << mainboard->getName() << ")"<< std::endl;
    }
};
 
 
/*------------------------*/
 
class Computer { 
   
public:
    Computer(CPU* cpu,
            VideoCard* videocard,
            MainBoard* mainboard) { 
   
        elementList.push_back(cpu);
        elementList.push_back(videocard);
        elementList.push_back(mainboard);
    };
    void Accept(Visitor* visitor) { 
   
        for( std::vector<Element*>::iterator i = elementList.begin(); i != elementList.end(); i++ )
        { 
   
            (*i)->accept(visitor);
        }
    }; 
private:
    std::vector<Element*> elementList;
};

结构

加粗样式

笔记

  • 就是将数据结构和操作 分离开
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168496.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月8日 上午10:16
下一篇 2022年8月8日 上午10:16


相关推荐

  • MVC设计模式和MVC框架的区别

    MVC设计模式和MVC框架的区别MVC 框架和 MVC 设计模式的区别

    2026年3月16日
    1
  • 装饰设计模式

    装饰设计模式就是对已有的对象的功能进行增强简单小例子:我们考虑一下使用继承也可以对父类中的功能进行增强只需要调用super就可以调用父类的方法,那使用装饰和继承有什么区别?使用继承体系就会有点臃肿

    2021年12月22日
    50
  • 十三、外观模式—— 简化接口 #和设计模式一起旅行#

    我不想成为上帝或英雄,只想成为一棵树,为岁月而生长,不伤害任何人。 ——米沃什故事背景在英国体验了康桥的魅力,我挥一挥衣袖,不带走一片云彩,但是 英国的天空没有留下我的痕迹,但我曾去过。哈哈!从英国到法国,在浪漫的巴黎,我和设计模式MM感受到这个城市别样的风景,很是吸引人,我们决定在这里待一段时间在走。于是去政府部门办理一些手续,本来以为会花费很多时间的,因为之前办…

    2022年2月27日
    45
  • 《JavaScript 模式》读书笔记(7)— 设计模式2

    这一篇我们主要来学习装饰者模式、策略模式以及外观模式。其中装饰者模式稍微复杂一点,大家认真阅读,要自己动手去实现一下哦。四、装饰者模式在装饰者模式中,可以在运行时动态添加附加功能到对象中。当处理静

    2022年3月25日
    46
  • Java常用设计模式

    Java常用设计模式一、设计模式概念1、定义​Java包含23种设计模式,是一套对代码设计经验的总结,被人们反复利用,多人熟知的代码设计方式。2、目的​为了提高代码的可读性,可扩展性以及代码的复用性,为了解决在写代码过程中遇到的代码设计问题。3、设计模式的六大原则​3.1开闭原则​对扩展开放,对修改关闭(尽可能对代码少修改)​3.2里氏替换原则​它是面向对象基本原则之一,任何父类(基类)出现的地方,子类都可以出现,也就是子类可以替换父类的任何功能(体现了父类的可扩展性)3.3依赖

    2022年7月8日
    25
  • 设计模式学习总结——观察者模式「建议收藏」

    设计模式学习总结——观察者模式

    2022年1月25日
    75

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号