IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 设计模式:visitor访问者模式 -> 正文阅读

[JavaScript知识库]设计模式:visitor访问者模式

在软件构建的过程中,由于需求的改变,常常需要在某类层次结构中增加新的方法(从基类到派生类都要),如果直接在基类中更改,就会破坏原有设计。
visitor模式可以在不改变各元素类的前提下“拓展”作用于这些元素的新变化。
本设计模式的主要点是double dispatch二次多态辨析
在这里插入图片描述
每个visitor派生类都可以定义新的element方法,这样就达到了不该变element结构设计而拓展功能的效果,当然这么做的设计前提是element在结构设计上已经稳定,及不会有新的派生类,要变化的只有增加操作方法。(这个前提一般很难达成)

#pragma once
#include <iostream>
using namespace std;

template<typename T>
class visitor;
template<typename T>
class Element {
public:
	virtual void accept(visitor<T>* vis) {

	}
};

template<typename T>
class concrete_element_1 :public Element<T> {
public:
	virtual void accept(visitor<T>* vis) {
		vis->visit_concrete_element_1(this);
	}
};

template<typename T>
class concrete_element_2 :public Element<T> {
public:
	virtual void accept(visitor<T>* vis) {
		vis->visit_concrete_element_2(this);
	}
};

template<typename T>
class visitor {
public:
	virtual void visit_concrete_element_1(concrete_element_1<T>* ele) {}
	virtual void visit_concrete_element_2(concrete_element_2<T>* ele) {}
};

template<typename T>
class visitor_1 :public visitor<T> {
public:
	virtual void visit_concrete_element_1(concrete_element_1<T>* ele) {
		cout << "正在使用visitor1附加的element1的附加方法" << endl;
	}
	virtual void visit_concrete_element_2(concrete_element_2<T>* ele) {
		cout << "正在使用visitor1附加的element2的附加方法" << endl;
	}
};

template<typename T>
class visitor_2 :public visitor<T> {
public:
	virtual void visit_concrete_element_1(concrete_element_1<T>* ele) {
		cout << "正在使用visitor2附加的element1的附加方法" << endl;
	}
	virtual void visit_concrete_element_2(concrete_element_2<T>* ele) {
		cout << "正在使用visitor2附加的element2的附加方法" << endl;
	}
};

测试接口

	//测试访问者模式
	cout << "测试访问者模式" << endl;
	auto ele1 = new concrete_element_1<bool>;
	auto ele2 = new concrete_element_2<bool>;
	auto vis1 = new visitor_1<bool>;
	auto vis2 = new visitor_2<bool>;
	ele1->accept(vis1);
	ele1->accept(vis2);
	ele2->accept(vis1);
	ele2->accept(vis2);
	cout << endl;
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-06 13:44:20  更:2022-02-06 13:44:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 2:30:38-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码