模板设计模式-实例

    在软件开发中,有时也会遇到类似的情况,某个方法的实现需要多个步骤(类似“请客”),其 中有些步骤是固定的(类似“点单”和“买单”),而有些步骤并不固定,存在可变性(类似“吃 东西”)。为了提高代码的复用性和系统的灵活性,可以使用一种称之为模板方法模式的设计 模式来对这类情况进行设计,在模板方法模式中,将实现功能的每一个步骤所对应的方法称 为基本方法(例如“点单”、“吃东西”和“买单”),而调用这些基本方法同时定义基本方法的执 行次序的方法称为模板方法(例如“请客”)。在模板方法模式中,可以将相同的代码放在父类 中,例如将模板方法“请客”以及基本方法“点单”和“买单”的实现放在父类中,而对于基本方 法“吃东西”,在父类中只做一个声明,将其具体实现放在不同的子类中,在一个子类中提 供“吃面条”的实现,而另一个子类提供“吃满汉全席”的实现。通过使用模板方法模式,一方面 提高了代码的复用性,另一方面还可以利用面向对象的多态性,在运行时选择一种具体子 类,实现完整的“请客”方法,提高系统的灵活性和可扩展性。 模板方法模式定义如下: 模板方法模式:定义一个操作中算法的框架,而将一些步骤延迟到子类中。模板方法模 式使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。 Template Method Pattern: Define the skeleton of an algorithm in an operation, deferring some steps to subclasses. Template Method lets subclasses redefine certain steps of an algorithm without changing the algorithm's structure.

    模板方法模式是一种基于继承的代码复用技术,它是一种类行为型模式。 模板方法模式是结构最简单的行为型设计模式,在其结构中只存在父类与子类之间的继承关 系。通过使用模板方法模式,可以将一些复杂流程的实现步骤封装在一系列基本方法中,在 抽象父类中提供一个称之为模板方法的方法来定义这些基本方法的执行次序,而通过其子类 来覆盖某些步骤,从而使得相同的算法框架可以有不同的执行结果。模板方法模式提供了一 个模板方法来定义算法框架,而某些具体步骤的实现可以在其子类中完成。

数据查询表多个情况下,存在很多冗余代码。getCapk函数的代码。getAid函数的代码query函数的代码都有点重复,但是又不完全相同。但是冗余代码太多了又什么好的设计模式能处理好这个情况?

 public List<EMV_CAPK> getCapk(int acquirerIdx) {SQLiteDatabase db = emvDbHelper.getReadableDatabase();List<EMV_CAPK> capkList = new ArrayList<>();String[] columns = {EmvDbHelper.rid,EmvDbHelper.capkIndex,EmvDbHelper.keyExp,EmvDbHelper.keyMod,EmvDbHelper.checksum};String selection = EmvDbHelper.acquirerId + " = ?";String[] selectionArgs = {String.valueOf(acquirerIdx)};Cursor cursor = db.query(EmvDbHelper.TABLE_CAPK,columns,selection,selectionArgs,null,null,null);while (cursor.moveToNext()) {EMV_CAPK emvCapk = createEMVCapkFromCursor(cursor);capkList.add(emvCapk);}cursor.close();db.close();return capkList;}
 public String query(int acquirerIdx) {String version = null;SQLiteDatabase db = emvDbHelper.getReadableDatabase();// 定义要查询的列String[] columns = {EmvDbHelper.tableVersion};// 设置查询条件String selection = EmvDbHelper.acquirerId + " = ?";String[] selectionArgs = {String.valueOf(acquirerIdx)};Cursor cursor = db.query(EmvDbHelper.TABLE_ACQUIRER,columns,selection,selectionArgs,null,null,null);if (cursor.moveToFirst()) {// 尝试获取 tableVersion 列的索引int tableVersionIndex = cursor.getColumnIndex(EmvDbHelper.tableVersion);// 检查索引是否有效if (tableVersionIndex >= 0) {// 列存在,可以安全地访问version = cursor.getString(tableVersionIndex);}}cursor.close();db.close();return version;}

改良后的代码。

public abstract class DatabaseQueryTemplate {protected EmvDbHelper emvDbHelper;protected String tableName;public DatabaseQueryTemplate(EmvDbHelper emvDbHelper) {this.emvDbHelper = emvDbHelper;}public DatabaseQueryTemplate(EmvDbHelper emvDbHelper, String tableName) {this.emvDbHelper = emvDbHelper;this.tableName = tableName;}public Map<String, Object> executeQuery(String[] columnsToSelect, String selectionColumn, String selectionValue) {SQLiteDatabase db = emvDbHelper.getReadableDatabase();Cursor cursor = db.query(tableName,columnsToSelect,selectionColumn + " = ?",new String[]{selectionValue},null,null,null);Map<String, Object> result = new HashMap<>();if (cursor.moveToFirst()) {result = DatabaseUtil.getColumnValues(cursor, columnsToSelect);}cursor.close();db.close();return result;}protected abstract void processRow(Cursor cursor);
}
public class AidQuery extends DatabaseQueryTemplate {private List<Tables.AidTable> result;public AidQuery(EmvDbHelper emvDbHelper) {super(emvDbHelper, EmvDbHelper.TABLE_AID);result = new ArrayList<>();}public List<Tables.AidTable> getResult() {return result;}@Overrideprotected void processRow(Cursor cursor) {}
}
   public String getAcqIndexList(String aid){AidQuery aidQuery = new AidQuery(emvDbHelper);String[] columnsToSelect = {EmvDbHelper.acquirerId,EmvDbHelper.aidIndex};String selectionColumn = EmvDbHelper.aid;String selectionValue = aid;Map<String, Object> result = aidQuery.executeQuery(columnsToSelect, selectionColumn, selectionValue);// 在这里可以根据需要处理 result,例如将其转换为字符串返回// 以下代码是示例,具体处理逻辑根据实际需求修改StringBuilder resultString = new StringBuilder();for (String columnName : columnsToSelect) {Object columnValue = result.get(columnName);if (columnValue != null) {resultString.append(columnValue);}}return resultString.toString();}
String acqIndexList = dbManager.getAcqIndexList(aid);Logs.d(TAG,"acqIndexList= "+ acqIndexList);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/618262.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

性能测试分析案例-使用动态追踪定位性能瓶颈

所谓动态追踪&#xff0c;就是在系统或者应用程序正常运行的时候&#xff0c;通过内核中提供的探针&#xff0c;来动态追踪它们的行为&#xff0c;从而辅助排查出性能问题的瓶颈。 使用动态追踪&#xff0c;可以在不修改代码、不重启服务的情况下&#xff0c;动态了解应用程序或…

点的旋转变换

情形一&#xff08;active or alibi transformation主动变换&#xff09; 在坐标系 x − y x-y x−y中&#xff0c;点 p 1 p_1 p1​逆时针旋转 α \alpha α后到达点 p 2 p_2 p2​。 p 1 p_1 p1​在 x − y x-y x−y中的表示与 p 2 p_2 p2​在 x ′ − y ′ x-y x′−y′中的表…

数据结构初探:揭开数据结构奥秘

&#x1f308;个人主页&#xff1a;聆风吟 &#x1f525;系列专栏&#xff1a;数据结构、算法模板、汇编语言 &#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 文章目录 &#x1f4cb;前言一. 数组结构起源二. 基本概念和术语2.1 数据2.2 数据元素2.3 数据项2.4 …

Linux第27步_在虚拟机中安装“设备树编译工具”

设备树英文名字叫做Device tree&#xff0c;用来描述板子硬件信息的&#xff0c;比如开发板上的 CPU有几个核 、每个CPU核主频是多少&#xff0c;IIC、SPI这些外设的寄存器范围是多少&#xff0c;IIC接口下都挂了哪些设备等等。 设备树文件是一种文本格式的文件&#xff0c;方…

小程序中滚动字幕

需求&#xff1a;在录像时需要在屏幕上提示字幕&#xff0c;整体匀速向上滚动 html部分&#xff1a; <view class"subtitles_main"><view style"font-size:34rpx;color: #fff;line-height: 60rpx;" animation"{{animation}}">人生的…

React16源码: React中的schedule调度整体流程

schedule调度的整体流程 React Fiber Scheduler 是 react16 最核心的一部分&#xff0c;这块在 react-reconciler 这个包中这个包的核心是 fiber reconciler&#xff0c;也即是 fiber 结构fiber的结构帮助我们把react整个树的应用&#xff0c;更新的流程&#xff0c;能够拆成每…

对git中tag, branch的重新理解

1. 问题背景 项目中之前一个tag&#xff08;v1.0&#xff09;打错了&#xff0c;想删除它&#xff0c;但我们从此tag v1.0中迁出新建分支Branch_v1.0,在此分支下修复了bug&#xff0c;想重新打一个tag v1.0&#xff0c;原来的tag v1.0可以删除掉吗&#xff1f; 错误的理解&am…

Mysql如何优化慢查询

如何优化慢查询 慢 SQL 的优化&#xff0c;主要从两个方面考虑&#xff0c;SQL 语句本身的优化&#xff0c;以及数据库设计的优化。 1、避免不必要的列 覆盖索引会导致回表&#xff0c;且增大了IO 2、分页优化 深分页解决方案 使用子查询in 使用连接表 left join 使用游标&a…

计算机毕业设计-----SSH计算机等级考试报名系统

项目介绍 该项目分为前后台&#xff0c;分为管理员与普通用户两种角色&#xff0c;前台为普通用户登录&#xff0c;后台为管理员登录&#xff1b; 管理员角色包含以下功能&#xff1a; 管理员登录,修改个人密码&#xff0c;院系信息管理&#xff0c;注册用户管理&#xff0c;留…

JAVA数组以及小练习

目录 数组的概述和静态初始化 数组的地址值和元素访问 数组的遍历 数组的动态初始化 数组练习 数组的概述和静态初始化 package 数组;public class array1 {public static void main(String[] args){//格式//静态初始化//数据类型 [] 数组名 new 数组类型[]{元素1&#xf…

java期末复习题

1.任何一个Java程序都默认引入一个包&#xff0c;这个包的名字是________________。 正确答案&#xff1a;java.lang Java程序默认引入的包是java.lang包。这个包是Java语言的核心&#xff0c;它提供了Java中的基础类&#xff0c;包括基本Object类、Class类、String类、基本类…

【模块系列】STM32BMP280

前言 最进想练习下I2C的应用&#xff0c;手上好有BMP280也没用过&#xff0c;就看着机翻手册和原版手册&#xff0c;开始嘎嘎写库函数了。库的命名应该还1是比较规范了吧&#xff0c;就是手册对于最终值的计算方式很迷糊&#xff0c;所以现在也不能保证有可靠性啊&#xff0c;大…

磁盘直通卡/阵列卡讲解

服务器SAS卡 ① 华为SR120 (LSI 2308 6Gb SAS直通卡),适合数据安全等级不高或 更换简单 硬盘即插即用 ② 华为SR320 (LSI 2208 6Gb SAS阵列卡 带512M缓存),适合对数据安全等级要求高或追求磁盘性能的客户 推荐上阵列卡 ③ 华为SR130 (LSI 3008 12Gb SAS直通卡),适合数据安全等…

【Spring 篇】深入探索:Spring集成Web环境的奇妙世界

嗨&#xff0c;亲爱的小白们&#xff01;欢迎来到这篇有关Spring集成Web环境的博客。如果你曾对如何在Spring中构建强大的Web应用程序感到好奇&#xff0c;那么这里将为你揭示Web开发的神秘面纱。我们将用情感丰富、语句通顺的文字&#xff0c;以小白友好的方式&#xff0c;一探…

Mac M2芯片pycharm配置conda python环境

Mac M2芯片pycharm配置conda python环境 详细步骤如下 1、pycharm界面右上方的小齿轮⚙️&#xff0c;进入Setting…状态 2、进入setting界面后&#xff0c;选择左边栏的Project-->python Interpreter,然后选择右边的Add Interpreter 3、进入Add Interpreter后&#xff0c…

竞赛保研 基于深度学的图像修复 图像补全

1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 基于深度学的图像修复 图像补全 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f9ff; 更多资料, 项目分享&#xff1a; https://gitee.com/dancheng-se…

内网穿透远程访问

内网穿透远程访问 参考文章&#xff1a;https://blog.csdn.net/qyj19920704/article/details/135528078#comments_30865140 cpolar概述 使用了 cpolar 生成的隧道&#xff0c;其公网地址是随机生成的。 优势在于建立速度快&#xff0c;可以立即使用。然而&#xff0c;它的缺…

selenium模拟浏览器查询导出参考文献

通过使用Selenium和BeautifulSoup&#xff0c;在CNKI网站上&#xff0c;以"知识图谱"为关键词&#xff0c;通过自动化工具在搜索页面提取相关文章信息。点击清楚并全选进行文献导出&#xff0c;随后从导出页面和管理导出的页面提取参考文献。 浏览器及WebDriver下载…

postgresql迁移到mysql

1.工具方法&#xff1a;Navicat Premium16 2. 手工方法&#xff1a; 迁移流程 下面是将 Postgresql 数据库迁移到 MySQL 的步骤流程&#xff1a; 步骤描述1. 创建MySQL表结构在MySQL中创建与Postgresql中的表结构相同的表2. 导出Postgresql数据将Postgresql中的数据导出为SQ…

评估指标中的RMSE,MAE,MAPE分别表示什么,取值范围一般多大,优缺点有哪些?

评价指标 1. RMSE&#xff08;Root Mean Square Error&#xff09;&#xff1a;均方根误差2. MAE&#xff08;Mean Absolute Error&#xff09;&#xff1a;平均绝对误差&#xff0c;也叫均方误差3. MAPE&#xff08;Mean Absolute Percentage Error&#xff09;&#xff1a;平…