小编给大家分享一下C++如何实现模板方法模式,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!
外观模式
目录
模式定义
模板方法模式(Facade),定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
模式动机
UML类图
源码实现 abstractclass.h
class AbstractClass
{
public:
AbstractClass();
virtual ~AbstractClass();
void MethodA();
virtual int MethodB(int a = 0, int b = 0);
};
abstractclass.cpp
#include "abstractclass.h"
#include <iostream>
AbstractClass::AbstractClass()
{
}
AbstractClass::~AbstractClass()
{
}
void AbstractClass::MethodA()
{
std::cout << __FUNCTION__ << " Call method b :" << this->MethodB(5, 4) << std::endl;
}
int AbstractClass::MethodB(int a, int b)
{
return a + b;
}
concreteclassa.h
#include "abstractclass.h"
class ConcreteClassA : public AbstractClass
{
public:
ConcreteClassA();
int MethodB(int a = 0, int b = 0) override;
};
concreteclassa.cpp
#include "concreteclassa.h"
ConcreteClassA::ConcreteClassA()
{
}
int ConcreteClassA::MethodB(int a, int b)
{
return a * b;
}
concreteclassb.h
#include "concreteclassb.h"
ConcreteClassB::ConcreteClassB()
{
}
int ConcreteClassB::MethodB(int a, int b)
{
return a - b;
}
concreteclassb.cpp
#include "concreteclassb.h"
ConcreteClassB::ConcreteClassB()
{
}
int ConcreteClassB::MethodB(int a, int b)
{
return a - b;
}
main.cpp
#include <iostream>
#include "concreteclassa.h"
#include "concreteclassb.h"
using namespace std;
int main()
{
ConcreteClassA* classA = new ConcreteClassA();
classA->MethodA();
ConcreteClassB* classB = new ConcreteClassB();
classB->MethodA();
return 0;
}
运行结果
MethodA Call method b :20
MethodA Call method b :1
优点
模板方法模式的优点
看完了这篇文章,相信你对C++如何实现模板方法模式有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。