访问者模式详解

访问者模式

简介: 类的内部结构不变的情况下,不同的访问者访问这个对象都会呈现出不同的处理方式。
人话: 其实就是为了解决类结构不变但操作处理逻辑易变的问题,把对数据的操作都封装到访问者类中,

我们只需要调用不同的访问者,而无需改变改变结构类,实现了。

举个理发店的例子

理发店:
用户分为: 普通用户 和 会员用户
toney老师分为: 技师, 总监, 店长
不通的用户有不通的老师

正常思路:
一个客户类, 一个理发师类
然后理发师类中针对不通的客户进行收费

问题: 
我们不想动理发师类, 因为在理发店的这个环境下, 理发师类肯定是比消费者类复杂很多的, 所以我们
使用访问者模式, 将数据的处理逻辑放到访问者里面, 这样理发师就不用经常修改了

访问者模式:
访问者类: 客户类, 实现visit方法
被访问者类: 理发师类, 实现accept方法

`代码``如下所示

cpp 复制代码
class ToneyTeacher;

class Customer
{
public:
	string name;
	Customer(string n) : name(n) {};
	virtual double visit(ToneyTeacher* t) =0;
};


class ToneyTeacher
{
private:
	int price = 0;
	string name;
public:
	ToneyTeacher(string n, int p) :name(n), price(p) {};
	int get_price() { return price; };
	ToneyTeacher(int p) : price(p) {};
	void accept(Customer* c);
};



class NormalCustomer : public Customer
{
public:
	NormalCustomer(string name) : Customer(name) {};
	double visit(ToneyTeacher* t) override
	{
		return 1 * t->get_price();
	}
};


class VIPCustomer : public Customer
{
public:
	VIPCustomer(string name) : Customer(name) {};
	double visit(ToneyTeacher* t) override
	{
		return 0.8 * t->get_price();
	}
};


void ToneyTeacher::accept(Customer* c)
{
	cout << name << "原价: " << price << ", 收 " << c->name << " 费用: " << c->visit(this) << endl;
}


int main()
{

	VIPCustomer* vip_c = new VIPCustomer("vip客户");
	NormalCustomer* normal_c = new NormalCustomer("普通客户");

	ToneyTeacher* t1 = new ToneyTeacher("技师", 10);
	ToneyTeacher* t2 = new ToneyTeacher("总监", 20);
	ToneyTeacher* t3 = new ToneyTeacher("店长", 30);

	t1->accept(vip_c);
	t2->accept(vip_c);
	t3->accept(vip_c);

	t1->accept(normal_c);
	t2->accept(normal_c);
	t3->accept(normal_c);

	return 0;
}

执行结果

相关推荐
Mongxin_Chan15 分钟前
【Cpp】指针与引用
c++·算法
SSL_lwz39 分钟前
P11290 【MX-S6-T2】「KDOI-11」飞船
c++·学习·算法·动态规划
熬夜学编程的小王1 小时前
【C++篇】从基础到进阶:全面掌握C++ List容器的使用
开发语言·c++·list·双向链表·迭代器失效
悄悄敲敲敲1 小时前
C++:智能指针
开发语言·c++
zhangpz_1 小时前
c ++零基础可视化——vector
c++·算法
萨达大1 小时前
23种设计模式-模板方法(Template Method)设计模式
java·c++·设计模式·软考·模板方法模式·软件设计师·行为型设计模式
刀鋒偏冷1 小时前
ninja: error: ‘/opt/homebrew/Cellar/opensslxxx/xx/lib/libssl.dylib
c++
理论最高的吻2 小时前
98. 验证二叉搜索树【 力扣(LeetCode) 】
数据结构·c++·算法·leetcode·职场和发展·二叉树·c
沈小农学编程2 小时前
【LeetCode面试150】——202快乐数
c++·python·算法·leetcode·面试·职场和发展
ZZZ_O^O2 小时前
【动态规划-卡特兰数——96.不同的二叉搜索树】
c++·学习·算法·leetcode·动态规划