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;
相关推荐
blasit21 小时前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
七月丶1 天前
别再手动凑 PR 了:这个 AI Skill 会按仓库习惯自动建分支、拆提交、提 PR
人工智能·设计模式·程序员
刀法如飞1 天前
从程序员到架构师:6大编程范式全解析与实践对比
设计模式·系统架构·编程范式
九狼1 天前
Flutter + Riverpod +MVI 架构下的现代状态管理
设计模式
静水流深_沧海一粟2 天前
04 | 别再写几十个参数的构造函数了——建造者模式
设计模式
StarkCoder2 天前
从UIKit到SwiftUI的迁移感悟:数据驱动的革命
设计模式
肆忆_2 天前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++
不想写代码的星星2 天前
虚函数表:C++ 多态背后的那个男人
c++
阿星AI工作室2 天前
给openclaw龙虾造了间像素办公室!实时看它写代码、摸鱼、修bug、写日报,太可爱了吧!
前端·人工智能·设计模式
_哆啦A梦3 天前
Vibe Coding 全栈专业名词清单|设计模式·基础篇(创建型+结构型核心名词)
前端·设计模式·vibecoding