设计模式之模板模式(C++)

简介: 设计模式之模板模式(C++)

一、模板模式是什么?

      模板模式是一种行为型的软件设计模式,在父类中定义了一个模板算法,只实现模板中的公共部分,将可变部分放在子类中实现,不同的子类对同一模板有不同的扩展和实现。


      模板模式的优点:


  1. 良好复用性。父类中公共部分可以多次使用,具备好的环境适应性。
  2. 良好扩展性。子类对父类模板的具体实现作扩展。
  3. 符合开闭原则。基于模板扩展功能,不需要改动原有代码。

     模板模式的缺点:


  1. 类个数增加。基于模板的每个实现,都要定义一个子类,容易使代码量膨胀。
  2. 若父类模板有改动,则子类均要同步更改。

二、模板模式

2.1 结构图

      客户端即Main主函数,定义好模板框架,具体步骤的实现交给子类完成。

2.2 代码示例

      场景描述:我是一个电脑店的老板,给我的徒弟们培训了一个大致的电脑安装教程,徒弟根据不同品牌不同客户的需求,参照我的教程完成安装。

//Template.h
/****************************************************/
#pragma once
#include <iostream>
#include <unordered_map>
#include <vector>
#include <list>
#include <string>
using namespace std;
// 定义模板类-电脑
class Computer 
{
public:
  // 装配
  void install() {
    cout << "电脑安装开始。" << endl;
    cout << "电脑品牌为:" << getComputerType() << endl;
    installProcessor();
    installMemory();
    installCaliche();
    cout << "电脑安装结束。" << endl;
  }
private:
  // 获取电脑类型
  virtual string getComputerType() = 0;
  // 安装处理器
  virtual void installProcessor() = 0;
  // 安装内存
  virtual void installMemory() = 0;
  // 安装硬盘
  virtual void installCaliche() = 0;
};
// 实现具体模板类-惠普电脑
class HPComputer : public Computer 
{
private:
  // 获取电脑类型
  virtual string getComputerType() {
    return "惠普";
  }
  // 安装处理器
  virtual void installProcessor() {
    cout << "安装处理器:Inter 酷睿i7-1260P" << endl;
  }
  // 安装内存
  virtual void installMemory() {
    cout << "安装内存:32GB DDR4-3200MHz" << endl;
  }
  // 安装硬盘
  virtual void installCaliche() {
    cout << "安装硬盘:1TB SSD" << endl;
  }
};
// 实现具体模板类-戴尔电脑
class DellComputer : public Computer 
{
private:
  // 获取电脑类型
  virtual string getComputerType() {
    return "戴尔";
  }
  // 安装处理器
  virtual void installProcessor() {
    cout << "安装处理器:Inter 酷睿i7-1265U" << endl;
  }
  // 安装内存
  virtual void installMemory() {
    cout << "安装内存:16GB DDR4-3200MHz" << endl;
  }
  // 安装硬盘
  virtual void installCaliche() {
    cout << "安装硬盘:512GB SSD" << endl;
  }
};
//main.cpp
/****************************************************/
#include <iostream>
#include <string>
#include "Template.h"
using namespace std;
int main() 
{
  Computer *computerA = new HPComputer();
  Computer *computerB = new DellComputer();
  computerA->install();
  cout << endl;
  computerB->install();
  delete computerA;
  delete computerB;
  computerA = nullptr;
  computerB = nullptr;
  return 0;
}

     程序结果如下。

      看过我“建造者模式”篇的小伙伴应该会发现,这两篇举的例子都是安装电脑。但是建造者模式中有一个“监工”负责落实建造的具体步骤和顺序,而模板模式中是父类承担了这个职责。

三、总结

      我尽可能用较通俗的话语和直观的代码例程,来表述我对模板模式的理解,或许有考虑不周到的地方,如果你有不同看法欢迎评论区交流!希望我举的例子能帮助你更好地理解模板模式。

      如果文章帮助到你了,可以点个赞让我知道,我会很快乐~加油!

相关文章
|
1月前
|
缓存 算法 程序员
C++STL底层原理:探秘标准模板库的内部机制
🌟蒋星熠Jaxonic带你深入STL底层:从容器内存管理到红黑树、哈希表,剖析迭代器、算法与分配器核心机制,揭秘C++标准库的高效设计哲学与性能优化实践。
C++STL底层原理:探秘标准模板库的内部机制
|
6月前
|
设计模式 Java 数据库连接
【设计模式】【创建型模式】工厂方法模式(Factory Methods)
一、入门 什么是工厂方法模式? 工厂方法模式(Factory Method Pattern)是一种创建型设计模式,它定义了一个用于创建对象的接口,但由子类决定实例化哪个类。工厂方法模式使类的实例化延迟
200 16
|
6月前
|
设计模式 负载均衡 监控
并发设计模式实战系列(2):领导者/追随者模式
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发设计模式实战系列,第二章领导者/追随者(Leader/Followers)模式,废话不多说直接开始~
208 0
|
6月前
|
设计模式 监控 Java
并发设计模式实战系列(1):半同步/半异步模式
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发设计模式实战系列,第一章半同步/半异步(Half-Sync/Half-Async)模式,废话不多说直接开始~
192 0
|
6月前
|
设计模式 安全 Java
并发设计模式实战系列(12):不变模式(Immutable Object)
🌟 大家好,我是摘星!🌟今天为大家带来的是并发设计模式实战系列,第十二章,废话不多说直接开始~
163 0
|
6月前
|
设计模式 算法 Java
设计模式觉醒系列(04)策略模式|简单工厂模式的升级版
本文介绍了简单工厂模式与策略模式的概念及其融合实践。简单工厂模式用于对象创建,通过隐藏实现细节简化代码;策略模式关注行为封装与切换,支持动态替换算法,增强灵活性。两者结合形成“策略工厂”,既简化对象创建又保持低耦合。文章通过支付案例演示了模式的应用,并强调实际开发中应根据需求选择合适的设计模式,避免生搬硬套。最后推荐了JVM调优、并发编程等技术专题,助力开发者提升技能。
|
5月前
|
存储 算法 安全
c++模板进阶操作——非类型模板参数、模板的特化以及模板的分离编译
在 C++ 中,仿函数(Functor)是指重载了函数调用运算符()的对象。仿函数可以像普通函数一样被调用,但它们实际上是对象,可以携带状态并具有更多功能。与普通函数相比,仿函数具有更强的灵活性和可扩展性。仿函数通常通过定义一个包含operator()的类来实现。public:// 重载函数调用运算符Add add;// 创建 Add 类的对象// 使用仿函数return 0;
209 0
|
5月前
|
人工智能 机器人 编译器
c++模板初阶----函数模板与类模板
class 类模板名private://类内成员声明class Apublic:A(T val):a(val){}private:T a;return 0;运行结果:注意:类模板中的成员函数若是放在类外定义时,需要加模板参数列表。return 0;
162 0
|
6月前
|
设计模式 Prometheus 监控
并发设计模式实战系列(20):扇出/扇入模式(Fan-Out/Fan-In)(完结篇)
🌟 大家好,我是摘星!🌟今天为大家带来的是并发设计模式实战系列,第二十章,废话不多说直接开始~
229 0
|
8月前
|
编译器 C++
模板(C++)
本内容主要讲解了C++中的函数模板与类模板。函数模板是一个与类型无关的函数家族,使用时根据实参类型生成特定版本,其定义可用`typename`或`class`作为关键字。函数模板实例化分为隐式和显式,前者由编译器推导类型,后者手动指定类型。同时,非模板函数优先于同名模板函数调用,且模板函数不支持自动类型转换。类模板则通过在类名后加`&lt;&gt;`指定类型实例化,生成具体类。最后,语录鼓励大家继续努力,技术不断进步!

热门文章

最新文章