设计模式(7)-模板(从事务处理应用的模板)
时间:2022-05-05
本文章向大家介绍设计模式(7)-模板(从事务处理应用的模板),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
首先看一个对于数据库操作的程序:
#include <iostream>
using namespace std;
class DataOper{
public:
void insertStu(){
cout<<"开连接..."<<endl;
cout<<"开启事务..."<<endl;
cout<<"执行insert()操作"<<endl;
cout<<"提交事务..."<<endl;
cout<<"关连接..."<<endl;
}
void updateStu(){
cout<<"开连接..."<<endl;
cout<<"开启事务..."<<endl;
cout<<"执行update()操作"<<endl;
cout<<"提交事务..."<<endl;
cout<<"关连接..."<<endl;
}
void deleteStu(){
cout<<"开连接..."<<endl;
cout<<"开启事务..."<<endl;
cout<<"执行delete()操作"<<endl;
cout<<"提交事务..."<<endl;
cout<<"关连接..."<<endl;
}
};
void main(){
DataOper* dataOper = new DataOper();
dataOper->insertStu();
dataOper->updateStu();
dataOper->deleteStu();
}
我们看运行结果有多个重复的操作
如何避免呢,就是使用模板把我们不需要重复操作的地方封装起来。
看一下新版代码:
#include <iostream>
using namespace std;
class DataTemplate{
private:
void beginConnection(){
cout<<"开连接..."<<endl;
}
void beginTransation(){
cout<<"开启事务..."<<endl;
}
void commitTransation(){
cout<<"提交事务..."<<endl;
}
void closeConnection(){
cout<<"关连接..."<<endl;
}
public:
virtual void insertData() = 0;
virtual void updateData() = 0;
virtual void deleteData() = 0;
void insertStu(){
beginConnection();
beginTransation();
insertData();
commitTransation();
closeConnection();
}
void updateStu(){
beginConnection();
beginTransation();
updateData();
commitTransation();
closeConnection();
}
void deleteStu(){
beginConnection();
beginTransation();
deleteData();
commitTransation();
closeConnection();
}
};
class DataDeal : public DataTemplate{
public:
virtual void insertData(){
cout<<"执行insert()操作"<<endl;
}
virtual void updateData(){
cout<<"执行update()操作"<<endl;
}
virtual void deleteData(){
cout<<"执行delete()操作"<<endl;
}
};
void main(){
DataDeal* dataDeal = new DataDeal();
dataDeal->insertStu();
dataDeal->updateStu();
dataDeal->deleteStu();
}
执行一下结果:
结果相同,但是看看我们的类里少了很多处理程序,我们只需要关心我们要处理的业务逻辑就可以了。
模板方法的效用一:节省子类代码。
这样,如果我们在父类把方法全部abstract,那么我们就没有做到减少子类代码的作用。
因此,写模板方法很容易,但是写一个好的模板方法就没那么容易了。
我们要做到良好的抽取,把固定的实现方法放在父类方法中去实现。
模板方法效用二:防止调用操作
在很多关于设计模式的书上,都是把父类的模板方法换成了一个简单的方法的堆积,如Display**1,Display*2等等。这样就给很多读者造成了一种错觉,觉得模板方法就是去调用下面的方法,其实并不尽然。
后面会继续谈到与其它模式的运用组合。
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(4)-创建项目解决方案
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(3)-漂亮系统登陆界面
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(2)-easyui构建前端页面框架[附源码]
- 扬言毁灭人类的索菲亚再一次挑战了人类
- SQL Server 存储过程生成insert语句
- silverlight 背景透明
- .Net 转战 Android 4.4 日常笔记(1)--工具及环境搭建
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(33)-MVC 表单验证
- 如何利用深度学习识别千万张图片?
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(32)-swfupload多文件上传[附源码]
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(31)-MVC使用RDL报表
- 43 Hot Flex and ActionScript 3.0 APIs, tips and tools for Autumn 2008
- 异步数据存储
- 谈谈基于SQL Server 的Exception Handling[中篇]
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法