设计模式-模板方法模式(TemplateMethod Pattern)

2024-03-23 02:18

本文主要是介绍设计模式-模板方法模式(TemplateMethod Pattern),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

模板方法模式(TemplateMethod Pattern)

基本概念:

模板方法模式从概念上讲,还是很容易理解的。需要执行两个任务,其中两个任务间既有共同的部分,又有不同的部分。那我们可以将两个任务重相同的部分提取出来,计划好流程,然后在后续执行任务过程中着重不同的部分。

比较抽象,但是好记得一句话(四个字)概括:分离异同。

具体应用举例:

    在笔者实际工作中,经常使用索尼的相机进行前端的采集设备。同样是索尼品牌相继,但是不同类型的相机既有相同的操作,也有不同的操作。本次只针对初始化操作这一部分进行举例。

    暂且给两款相机分别取代号x30和x30u, 其中x30在初始化的时候的基本流程是:发送connect code1 ---> 发送connect code2 ---> 设置时间格式 ---> 设置工作模式 ---> 设置初始化zoom position ---> 设置liveview分辨率 ---> 进入命令等待状态。  而对于x30u来说,不需要发送connect code2,工作模式是默认的,不需要设置,起始zoom position为0,不需要设置。在这种两者初始化既有相同部分,又有不同不分的情况下,可以使用模板方法模式来进行代码上的优化。

老规矩,直接上代码:

#include <QCoreApplication>#include <iostream>
#include <stdlib.h>using namespace std;class SonyCameraInit
{
public:void SendConnectCode1(){cout << "SendConnectCode1" << endl;}virtual void SendConnectCode2() = 0;void SetTimeFormat(){cout << "SetTimeFormat" << endl;}virtual void SetOperationMode() = 0;virtual void InitZoomPosition() = 0;void SetLiveviewResolution(){cout << "SetLiveviewResolution" << endl;}void WaitCommand(){cout << "WaitCommand..." << endl;}void Init(){SendConnectCode1();SendConnectCode2();SetTimeFormat();SetOperationMode();InitZoomPosition();SetLiveviewResolution();WaitCommand();}
};class Qx30Init: public SonyCameraInit
{
public:virtual void SendConnectCode2(){cout << "SendConnectCode2 for qx30" << endl;}virtual void SetOperationMode(){cout << "SetOperationMode for qx30" << endl;}virtual void InitZoomPosition(){cout << "InitZoomPosition for qx30" << endl;}
};class Qx30uInit: public SonyCameraInit
{virtual void SendConnectCode2(){cout << "Do not need SendConnectCode2 for qx30u" << endl;}virtual void SetOperationMode(){cout << "Do not need SetOperationMode for qx30u" << endl;}virtual void InitZoomPosition(){cout << "Do not need InitZoomPosition for qx30u" << endl;}
};int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);SonyCameraInit* Qx30_init = new Qx30Init();Qx30_init->Init();cout<<"**********"<<endl;SonyCameraInit* Qx30u_init = new Qx30uInit();Qx30u_init->Init();return a.exec();}

看结果:

这篇关于设计模式-模板方法模式(TemplateMethod Pattern)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/836825

相关文章

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

SpringBoot集成EasyPoi实现Excel模板导出成PDF文件

《SpringBoot集成EasyPoi实现Excel模板导出成PDF文件》在日常工作中,我们经常需要将数据导出成Excel表格或PDF文件,本文将介绍如何在SpringBoot项目中集成EasyPo... 目录前言摘要简介源代码解析应用场景案例优缺点分析类代码方法介绍测试用例小结前言在日常工作中,我们经

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数