原型模式
模式简介
当一个对象需要完全拷贝另一个对象的状态时,需要使用这个模式。此时,拷贝的新对象和原来的对象拥有同样的行为状态。这么做的优势是,新建对象的时候,我们不需要人工把新对象改变到原来对象的状态,而是复制函数帮我们处理完毕了。
这个模式一般用在那些需要克隆有特定状态的对象。比如一个对象当前存储了某些特定的数值,这些值非常多而且复杂,那么此时就可以使用这个模式了。C++中通过拷贝构造函数来实现。
模式实现
需要有一个原型类的纯虚基类提供克隆函数,之后具体的子类继承这个纯虚基类,并实现自己的clone函数。
UML类图
代码实例
#include <iOStream>
#include <memory>
#include <string>
class prototype {
public:
virtual std::shared_ptr<Prototype> Clone() = 0;
// 这2个纯虚函数仅是为了显示用的
virtual std::string getName() const = 0;
virtual int getScore() const = 0;
};
class ConcretePrototype : public Prototype {
public:
ConcretePrototype() = default;
ConcretePrototype(ConcretePrototype& type) {
m_strName = type.m_strName;
m_iScore = type.m_iScore;
}
std::shared_ptr<Prototype> Clone() override {
return std::make_shared<ConcretePrototype>(*this);
}
void setName(std::string name) {
m_strName = std::move(name);
}
void setScore(int score) {
m_iScore = score;
}
std::string getName() const override {
return m_strName;
}
int getScore() const override {
return m_iScore;
}
private:
std::string m_strName;
int m_iScore{0};
};
int main() {
std::shared_ptr<Prototype> ptr;
ConcretePrototype cpt1, cpt2;
cpt1.setName("Tom");
cpt1.setScore(100);
ptr = cpt1.Clone();
std::cout << ptr->getName() << ", " << ptr->getScore() << std::endl;
cpt2.setName("Lily");
cpt2.setScore(97);
ptr = cpt2.Clone();
std::cout << ptr->getName() << ", " << ptr->getScore() << std::endl;
return 0;
}
文章最后发布于: 2019-06-11 11:10:19
相关阅读
上门按摩、上门足疗、上门美容,一夜之间啥都上门了,上门真的有那么强的需求么,这是真需求还是伪需求呢?O2O爆发本质上是人口学问题,上
设计模式本质上就是“SOLID设计原则”在实际应用中的具体体现,我们在实际开发中要尽量面向抽象编程、面向接口编程。顾客->菜单<-
对于产品人而言,SaaS是一个熟得不能再熟的概念了。然而,对一些尚未入门但对产品很感兴趣的小白来说,就会很疑惑SaaS到底是什么,SaaS产
《年入千万秘诀:分析《罗辑思维》的盈利模式》文章已经归档,不再展示相关内容,编辑建议你查看最新于此相关的内容:逻辑思维能力差的孩
随着中国国内消费升级,消费者对生活品质的要求不断增加,高品质高性能、天然有机成为吸引消费者购买产品的主要因素。虽然澳大利亚、