博客
关于我
设计模式之模板模式
阅读量: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 I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>