C++设计模式——访问器模式(Visitor)

访问器模式

在软件构建中,由于需求的变化,某些类层次结构中常常需要增加新的行为(方法),如果直接在基类中添加,会给子类带来繁重的变更负担,破坏原有设计。

访问器模式:表示一个作用于某对象结构中的各元素的操作。使得可以在不改变(稳定)各元素类的前提下定义(扩展)作用于这些元素的新操作(变化)。

#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类的层析结构稳定,而其中的方法经常面临变动”

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

dailingGuo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值