博客
关于我
设计模式之模板模式
阅读量:358 次
发布时间:2019-03-04

本文共 1297 字,大约阅读时间需要 4 分钟。

目录


模板模式template

概念

  • Template Method模式也叫模板方法模式,是行为模式之一,它把具有特定步骤算法中的某些必要的处理委让给抽象方法,通过子类继承对抽象方法的不同实现改变整个算法的行为。

应用场景

  • Template Method模式一般应用在具有以下条件的应用中:
    • 具有统一的操作步骤或操作过程
    • 具有不同的操作细节
    • 存在多个具有同样操作步骤的应用场景,但某些具体的操作细节却各不相同

总结

  • 在抽象类中统一操作步骤,并规定好接口
  • 子类实现接口。这样可以把各个具体的子类和操作步骤接耦合

角色和职责

  • AbstractClass:
    • 抽象类的父类
  • ConcreteClass:
    • 具体的实现子类
  • templateMethod():
    • 模板方法
  • method1()与method2():
    • 具体步骤方法  
       

案例

#include 
using namespace std;class MakeCar{public: virtual void makeHead() = 0; virtual void makeBody() = 0; virtual void makeTail() = 0;public: //把一组行为 变成 一个模板 void make() { makeHead(); makeBody(); makeTail(); }};class MakeBus : public MakeCar{public: virtual void makeHead() { cout << "bus 组装 车头" << endl; } virtual void makeBody() { cout << "bus 组装 车身" << endl; } virtual void makeTail() { cout << "bus 组装 车尾" << endl; }};class MakeJeep : public MakeCar{public: virtual void makeHead() { cout << "Jeep 组装 车头" << endl; } virtual void makeBody() { cout << "Jeep 组装 车身" << endl; } virtual void makeTail() { cout << "Jeep 组装 车尾" << endl; }};void main(){ MakeCar *bus = new MakeBus; //bus->makeHead(); //bus->makeBody(); //bus->makeTail(); bus->make(); MakeCar *jeep = new MakeJeep; //jeep->makeHead(); //jeep->makeBody(); //jeep->makeTail(); jeep->make(); delete bus; delete jeep; cout<<"hello..."<

【注】参考传智扫地僧C++设计模式

转载地址:http://taur.baihongyu.com/

你可能感兴趣的文章
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>