C++设计模式——访问器模式(Visitor)
2023-09-14 09:07:07 时间
访问器模式
在软件构建中,由于需求的变化,某些类层次结构中常常需要增加新的行为(方法),如果直接在基类中添加,会给子类带来繁重的变更负担,破坏原有设计。
访问器模式:表示一个作用于某对象结构中的各元素的操作。使得可以在不改变(稳定)各元素类的前提下定义(扩展)作用于这些元素的新操作(变化)。
#include<iostream>
using namespace std;
class Visitor;
class Element {
public:
virtual void accept(Visitor& visitor) = 0;//第一次多态辨析(找accept)
virtual ~Element() {}
};
class ElementA :public Element {
public:
virtual void accept(Visitor& visitor) override; //第二次多态辨析(找visitElementA)
};
class ElementB :public Element {
public:
void accept(Visitor& visitor) override;
};
class Visitor {
public:
virtual void visitElementA(ElementA& element) = 0;
virtual void visitElementB(ElementB& element) = 0;
virtual ~Visitor() {}
};
void ElementA::accept(Visitor& visitor) {
visitor.visitElementA(*this);//第二次多态辨析(找visitElementA)
}
void ElementB::accept(Visitor& visitor) {
visitor.visitElementB(*this);
}
//=================
//对行为进行更改
class Visiter1 :public Visitor {
public:
void visitElementA(ElementA& element) override {
cout << "Visitor1 process ElementA" << endl;
}
void visitElementB(ElementB& element) override {
cout << "Visitor1 process ElementB" << endl;
}
};
class Visiter2 :public Visitor {
public:
void visitElementA(ElementA& element) override {
cout << "Visitor2 process ElementA" << endl;
}
void visitElementB(ElementB& element) override {
cout << "Visitor2 process ElementB" << endl;
}
};
int main()
{
Visiter1 visitor;
ElementA elementA;
elementA.accept(visitor);//二次多态辨析
ElementB elementB;
elementB.accept(visitor);
return 0;
}
运行结果如下:
要点:
实现Visitor模式的前提是:子类必须稳定(个数确定),否则Visitor基类就要修改,违背了开闭原则。因此访问器模式只适用于“Element类的层析结构稳定,而其中的方法经常面临变动”
相关文章
- C++学习——c++逗号操作符说明(附加全部运算符优先级)
- 多线程C语言_多线程c++
- EasyC++17,C++指针初探(三)
- c++算法之最长递增子序列(LIS)
- C++ 单例模式_c 单例模式
- 汉罗塔c++递归_栈与递归的区别
- C++stl库_c++库
- C、C++ 和 Java 中的浮点运算和关联性
- c 线程安全的单例模式-详解C++实现线程安全的单例模式
- c++使用icu国际化(i18n)
- C++为什么会有这么多难搞的值类别
- 【C++】适配器模式 -- stack/queue/dqueue
- C++11 多线程编程 使用lambda创建std::thread (生产/消费者模式)详解编程语言
- C++ accumulate函数用法详解
- C++结构体完全攻略(超详细)
- C++中的单例模式(普通,2B,文艺)
- C++中的单例模式介绍
- c++一个二进制串转化为整数的解决方法
- 常用C/C++预处理指令详解