您好,登錄后才能下訂單哦!
小編給大家分享一下C++如何實(shí)現(xiàn)模板方法模式,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
外觀模式
目錄
模式定義
模板方法模式(Facade),定義一個(gè)操作中的算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類可以不改變一個(gè)算法的結(jié)構(gòu)即可重定義該算法的某些特定步驟。
模式動機(jī)
UML類圖
源碼實(shí)現(xiàn) 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; }
運(yùn)行結(jié)果
MethodA Call method b :20
MethodA Call method b :1
優(yōu)點(diǎn)
模板方法模式的優(yōu)點(diǎn)
看完了這篇文章,相信你對C++如何實(shí)現(xiàn)模板方法模式有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。