访问者模式

#include <iostream>
#include <vector>
#include <string>

using namespace std;

class Element;

class Visitor
{
public:
	virtual void visitElementOne(Element* pobjElement) = 0;
	virtual void visitElementTwo(Element* pobjElement) = 0;
};

class Element
{
public:
	Element(const string& strName) : m_strName(strName) {}
	virtual void accept(Visitor* pobjVisitor) = 0;
	void setName(const string& strName) { m_strName = strName; }
	const string& getName() { return m_strName; }
protected:
	string m_strName = "";
};

class VisitorOne : public Visitor
{
public:
	virtual void visitElementOne(Element* pobjElement) override
	{
		cout << pobjElement->getName() << " visitor one visits one" << endl;
	}
	virtual void visitElementTwo(Element* pobjElement) override
	{
		cout << pobjElement->getName() << " visitor one visits two" << endl;
	}
};

class VisitorTwo : public Visitor
{
public:
	virtual void visitElementOne(Element* pobjElement) override
	{
		cout << pobjElement->getName() << " visitor two visits one" << endl;
	}
	virtual void visitElementTwo(Element* pobjElement) override
	{
		cout << pobjElement->getName() << " visitor two visits two" << endl;
	}
};

class ElementOne : public Element
{
public:
	ElementOne(const string& strName) : Element(strName) {}
	virtual void accept(Visitor* pobjVisitor) override
	{
		pobjVisitor->visitElementOne(this);
	}
};

class ElementTwo : public Element
{
public:
	ElementTwo(const string& strName) : Element(strName) {}
	virtual void accept(Visitor* pobjVisitor) override
	{
		pobjVisitor->visitElementTwo(this);
	}
};

class ObjectStruct
{
public:
	void addElement(Element* pobjElement)
	{
		m_vecElement.push_back(pobjElement);
	}
	void removeElement(Element* pobjElement)
	{
		for (auto it = m_vecElement.begin(); it != m_vecElement.end(); ++it)
		{
			if (*it == pobjElement)
			{
				m_vecElement.erase(it);
				break;
			}
		}
	}
	void accept(Visitor* pobjVisitor)
	{
		for (auto& it : m_vecElement)
		{
			if (it)
			{
				it->accept(pobjVisitor);
			}
		}
	}
private:
	vector<Element*> m_vecElement;
};

int main()
{
	ObjectStruct objObjectStruct;
	objObjectStruct.addElement(new ElementOne("彳亍"));
	objObjectStruct.addElement(new ElementTwo("行"));
	Visitor* pobjVisitorOne = new VisitorOne();
	Visitor* pobjVisitorTwo = new VisitorTwo();
	objObjectStruct.accept(pobjVisitorOne);
	objObjectStruct.accept(pobjVisitorTwo);
	return 0;
}
总结:把处理从数据结构中分离,需要数据结构相对稳定
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值