首页 > 其他分享 >模板模式(template)

模板模式(template)

时间:2023-09-07 18:23:11浏览次数:48  
标签:调用 template doDish 子类 模式 模块 模板 函数

模板模式(Template)

1、作用

做一件是的方法很多,但做这件都可以归纳为几个步骤。这个时候可以使用模板模式,在模板类中,定义做事的步骤,将多种实现做事的细节延迟到子类中去实现。

即:定义一个操作中的算法的骨架(模板函数),而将一些步骤延迟到子类中(基本函数)。模板方法使得子类可以不改变一个算法的结构(模板函数)即可重定义该算法的实现方式(基本函数)。

开闭原则:对修改关闭、对扩展开发

依赖倒置(DIP dependency inversion principle):高层次模块不依赖与低层次模块(调用模块不依赖于被调用模块的修改和扩展,如果被调用模块是基于抽象类开发,那么调用模块只要基于抽象类调用即可。这样就出现了依赖倒置,即具体的类要依赖于抽象的类来实现,而不是抽象类或者调用模块依赖于被调用模块)。依赖倒置的原则就是:子类依赖于抽象基类实现,调用模块依赖于抽象基类调用,这样隔离了调用模块与具体实现的子类的依赖。(要求抽象基类定义的很好)

2、实现方式

比如做菜都分3个步骤:洗菜、切菜、炒菜。

但是做不同的菜每个步骤的细节不一样,这个时候就可以使用模板模式,在模板类(cook)中,将这三个步骤定义为纯虚函数(基本函数)、同时实现一个final的模板函数调用基本函数(洗菜、切菜、炒菜这三个顺序是固定的)。在实现炒不同菜的时候都通过继承这个模板,并根据每个菜的特定实现洗菜、切菜、炒菜三个基本函数。通过模板扩展可以实现炒不同的菜、且有一个统一的接口,方便扩展、使用和维护。

这里将模板函数定义为public的,而基本函数定义为protected的只用于给模板函数调用。

img

3、C++代码

DoDishTemplate.h

#include <iostream>

#ifndef __DO_DISH_TEMPLATE__H__
#define __DO_DISH_TEMPLATE__H__

using namespace std;

class DoDishTemplate {                  // 定义一个顶层框架,模板类定了执行基本函数的模板函数,而把基本函数的实现延迟到子类。
    protected:
        virtual void wash() = 0;        // 具体逻辑步骤的函数---->基本函数
        virtual void cut() = 0;
        virtual void cook() = 0;
    public:
        virtual void doDish() final {     // 将基本方法汇总起来的函数---->模板函数,为了防止恶意操作,模板函数都定义成final的。
            cout<<"step 1:";
            wash();
            cout<<"step 2:";
            cut();
            cout<<"step 3:";
            cook();
        }

};                                      // 封装不可变部分:模板函数   扩展可变部分:基本函数


class PotatoFloss : public DoDishTemplate {
    protected:
        void wash() override {
            cout<<"washing potatoes and remove the peel."<<endl;
        }

        void cut() override {
            cout<<"cut the potatoes into silk."<<endl;
        }

        void cook() override {
            cout<<"fried potato slices, add some vinegar."<<endl;
        }
};



class TomatoWithEggs : public DoDishTemplate {
    protected:
        void wash() override {
            cout<<"washing tomatoes."<<endl;
        }

        void cut() override {
            cout<<"cut tomatoes into pieces, beat eggs."<<endl;
        }

        void cook() override {
            cout<<"mix tomatoes and eggs together, then fry."<<endl;
        }
};


#endif

test.cc

#inlcude "DoDishTemplate.h"

int main() {
    DoDishTemplate *doDish = new PotatoFloss;
    doDish->doDish();

    doDish = new TomatoWithEggs;
    doDish->doDish();


    return 0;
}

输出:

img

标签:调用,template,doDish,子类,模式,模块,模板,函数
From: https://www.cnblogs.com/yuandonghua/p/17685770.html

相关文章

  • 外观模式(facade)
    外观模式(Facade)1、作用(1)、将各个子系统的接口汇聚在一起,定义一个统一的接口方便客户使用,满足“迪米特法则”,即客户不需要了解子系统,只需要知道Facade模式封装的类即可以使用所有子系统。(2)、隔离用户和子系统,将用户与子系统解耦,当子系统有修改是,顶多修改Facade模式封装的类,无需......
  • 桥接模式
    桥接模式1作用当类的模型有两个或多个维度的时候,如果两个变化维度用同一个类使用继承方式实现会变得很复杂(冗余代码很多),不易于维护和扩展(继承关系是一种强耦合关系),为了降低耦合关系,提高维护性和可扩展性,可以将两个变化维度的通过两个类(abstruction、implementor类)来实现,将两......
  • 韬客时代卷轴模式系统开发介绍和部分核心源码
    韬客时代是一种卷轴模式系统。什么是卷轴模式呢?新用户注册,先送你一部分积分,该积分用于兑换一个初始任务,俗称卷轴!卷轴模式的赚钱的原理是,你用积分兑换初级任务包,完成卷轴任务之后,你可以获得更多的积分,然后复投,达到一定数量后可以兑换更高级的任务包,任务包越高级每次获得的积分也就越......
  • kafka复习:(24)consume-transform-produce模式
    packagecom.cisdi.dsp.modules.metaAnalysis.rest.kafka2023;importorg.apache.kafka.clients.consumer.*;importorg.apache.kafka.clients.producer.KafkaProducer;importorg.apache.kafka.clients.producer.ProducerConfig;importorg.apache.kafka.clients.produc......
  • 区域LIS应用平台 云技术的SaaS模式
    在医疗机构内部,院内实验室主要负责本院临床科室的检验,院内LIS系统必须满足实验室日常的标本处理入库、仪器联机、检验结果处理、报告打印、报告发布、检验信息统计、检验信息报告发布、标本流程、外部医疗机构检验报告调阅等工作。 在医疗机构间,一方面在区域卫生信息平台上构建区......
  • 一文搞定,PO设计模式详解
    PO模式:全称:pageobjece,分层机制,让不同层去做不同类型的事情,让代码结构清晰,增加复⽤性。PO模式的优势:1)效率⾼:同理,PO模式的逻辑层⽅法有具体定义,情况和元素发⽣变化⼀样修改逻辑层,业务层不变。这样看来结构简单清晰,舒服更符合⼈类习惯,普通⽅式就是继续堆case。2)复⽤多收益⼤:同样......
  • 从追MM谈Java的23种设计模式
    1、FACTORY—追MM少不了请吃饭了,麦当劳的鸡翅和肯德基的鸡翅都是MM爱吃的东西,虽然口味有所不同,但不管你带MM去麦当劳或肯德基,只管向服务员说“来四个鸡翅”就行了。麦当劳和肯德基就是生产鸡翅的Factory.以下是引用片段:实例一:publicclassFactory{......
  • 12种微服务模式
    释放微服务的力量您是否正在努力构建高效、可扩展且有弹性的软件系统?作为软件开发人员或高级开发人员,您一定遇到过“微服务架构”一词。这种革命性的软件开发方法已被许多成功的科技巨头采用,例如Netflix、亚马逊和Spotify。但是,微服务到底是什么,你为什么要关心?微服务架构是一种软......
  • 行为型设计模式-备忘录 Memento
    简介允许在不暴露对象实现细节的情况下保存和恢复对象之前的状态,该状态保存在对象之外,这样就可以不破坏原有对象的封装性了。角色Originator原发器即需要被保存状态的类抽象Memento备忘录类定义备忘录基本接口可以看做成是快照Snapshot具体Memento备忘录类实......
  • 行为型设计模式-状态 State
    简介跟状态机密切相关。有限状态机FSM包含状态、事件、动作三个元素。当发生一个事件时,引发老状态变成新状态,并执行一个动作。状态和行为间一般是有限制的,如某些行为只能再某些状态下进行,某些状态只能触发某些行为。简单的状态间转换可使用ifelse。更有条理的可以用查表......