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;
相关推荐
大卫的纯爱战士1 小时前
c++指针和引用之高难度(二)习题讲解
开发语言·c++
潜水大王2 小时前
C++轻量级 线程间异步消息架构(向曾经工作的ROSA-RB以及共事的DOPRA的老兄弟们致敬)
c++·架构
画饼校长2 小时前
【C++ Primer Plus学习记录】函数的基本知识
开发语言·c++·学习·visualstudio·软件工程
情系明明2 小时前
使用c++设计一个计算器
数据结构·c++·算法
烛九_阴3 小时前
【讨论C++继承】
开发语言·c++
少年没有乌托邦。3 小时前
C++ 类与对象(中)
c++
“αβ”5 小时前
c语言的烫烫烫烫烫??
c语言·开发语言·c++
臻一6 小时前
C++编程(五)单例模式 友元
开发语言·c++·设计模式
小白要code7 小时前
设计模式-抽象工厂模式
java·设计模式·抽象工厂模式
莱茶荼菜8 小时前
c++ 线程安全与线程管理
开发语言·c++·安全