访问者模式详解

访问者模式

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

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

举个理发店的例子

复制代码
理发店:
用户分为: 普通用户 和 会员用户
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;
}

执行结果

相关推荐
xiaolang_8616_wjl1 小时前
c++文字游戏_闯关打怪2.0(开源)
开发语言·c++·开源
夜月yeyue1 小时前
设计模式分析
linux·c++·stm32·单片机·嵌入式硬件
无小道2 小时前
c++-引用(包括完美转发,移动构造,万能引用)
c语言·开发语言·汇编·c++
FirstFrost --sy3 小时前
数据结构之二叉树
c语言·数据结构·c++·算法·链表·深度优先·广度优先
Tanecious.4 小时前
C++--map和set的使用
开发语言·c++
Yingye Zhu(HPXXZYY)4 小时前
Codeforces 2021 C Those Who Are With Us
数据结构·c++·算法
liulilittle5 小时前
LinkedList 链表数据结构实现 (OPENPPP2)
开发语言·数据结构·c++·链表
无聊的小坏坏5 小时前
三种方法详解最长回文子串问题
c++·算法·回文串
山河木马5 小时前
前端学习C++之:.h(.hpp)与.cpp文件
前端·javascript·c++
2401_891957315 小时前
list的一些特性(C++)
开发语言·c++