C++ 设计模式之模板方法模式

C++ 设计模式之模板方法模式

简介

1、模板方法模式(Template Method)是一种行为型设计模式,它在一个方法中定义一个算法的骨架,而让一些步骤延迟到子类中。模板方法使得子类可以不改变一个算法的结构即可重新定义该算法的某些特定步骤。

2、模板方法模式 (Template Method)应用场景包括但不限于:

2.1、在算法框架固定,但具体步骤有所差异的情形下,如各种排序算法的框架。

2.2、当有许多共享相同的方法,但是有小部分需要各自实现的场合。

2.3、当需要控制子类扩展的点时。

3、模板方法模式 (Template Method)的构成

3.1、抽象类(Abstract Class):定义了一个或多个抽象操作,以及一个或多个非抽象的操作(即模板方法)。这些非抽象操作通常会调用抽象操作。

c 复制代码
class Game
{
public:
	void play();

protected:
	virtual void initialize() = 0;
	virtual void startPlay() = 0;
	virtual void endPlay() = 0;
};

3.2、具体子类(Concrete Subclass):实现抽象类中的抽象操作,从而提供了抽象操作的具体实现。

c 复制代码
class Chess : public Game
{
protected:
	void initialize();
	void startPlay();
	void endPlay();
};

4、模板方法模式 (Template Method)的优点

4.1、代码复用:通过将不变部分的代码移至父类,子类只需要实现变化的部分,这提高了代码复用。

4.2、扩展性好:新增具体类时,不需要改变抽象类和其他具体类的代码,保证了代码的可维护性和扩展性。

4.3、引入模板方法可以使子类的实现更加清晰,可维护性也更好。

4.4、实现了反向控制(依赖倒置),高层模块对低层模块的控制。

5、模板方法模式 (Template Method)的缺点

5.1、每一个不同的实现都需要一个子类来实现,这可能会导致系统中类的数目增加,增加了系统的复杂性。

5.2、父类中的抽象方法由子类实现,子类的执行结果会影响到父类的结果,也就是父类部分对子类产生的依赖性。

简单示例

1、定义

c 复制代码
class Game
{
public:
	void play();

protected:
	virtual void initialize() = 0;
	virtual void startPlay() = 0;
	virtual void endPlay() = 0;
};

class Chess : public Game
{
protected:
	void initialize();
	void startPlay();
	void endPlay();
};

class Monopoly : public Game
{
protected:
	void initialize();
	void startPlay();
	void endPlay();
};

2、实现

c 复制代码
void Game::play()
{
	initialize();
	startPlay();
	endPlay();
}

void Chess::initialize()
{
	std::cout << "Chess Game Initialized!" << std::endl;
}

void Chess::startPlay()
{
	std::cout << "Chess Game Started. Enjoy the game!" << std::endl;
}

void Chess::endPlay()
{
	std::cout << "Chess Game Finished!" << std::endl;
}

void Monopoly::initialize()
{
	std::cout << "Monopoly Game Initialized!" << std::endl;
}

void Monopoly::startPlay()
{
	std::cout << "Monopoly Game Started. Enjoy the game!" << std::endl;
}

void Monopoly::endPlay()
{
	std::cout << "Monopoly Game Finished!" << std::endl;
}

3、调用

c 复制代码
Game* game = new Chess();
game->play();
delete game;
std::cout << std::endl;
game = new Monopoly();
game->play();
delete game;
相关推荐
依旧阳光的老码农3 分钟前
log4cpp 编译说明文档
c++
OpenC++10 分钟前
【C++QT】Layout 布局管理控件详解
c++·经验分享·qt·leetcode
前端大白话18 分钟前
Vue2和Vue3语法糖差异大揭秘:一文读懂,开发不纠结!
javascript·vue.js·设计模式
前端大白话23 分钟前
JavaScript中`Symbol.for()`和`Symbol()`的区别,在创建全局唯一的`Symbol`值时如何选择使用?
前端·javascript·设计模式
1白天的黑夜144 分钟前
贪心算法-860.柠檬水找零-力扣(LeetCode)
c++·算法·leetcode·贪心算法
CHQIUU1 小时前
Java 设计模式心法之第25篇 - 中介者 (Mediator) - 用“中央协调”降低对象间耦合度
java·设计模式·中介者模式
BS_Li1 小时前
C++类和对象(上)
开发语言·c++·类和对象
超能力MAX1 小时前
关于C++中的指针值的传递
开发语言·c++
wuqingshun3141592 小时前
蓝桥杯 16. 密文搜索
c++·算法·职场和发展·蓝桥杯·深度优先
Pasregret2 小时前
备忘录模式:实现对象状态撤销与恢复的设计模式
运维·服务器·设计模式