IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 设计模式9——抽象工厂 -> 正文阅读

[大数据]设计模式9——抽象工厂

动机

??在软件设计中经常面对一系列相互依赖的对象的创建工作,由于需求变化,经常面对更多对象的创建工作。

1. 引入问题

代码如下:

class EmployeeDB
{
public:
	vector<EmployeeInfo> GetEmployee()
	{
		/* 创建SQL对象,建立初始网络连接 */
		SqlConnect *connection = new SqlConnection();
		connection->ConnectNet("ip:192.168.0.1");
		/* 创建command对象 */
		SqlCommand *command = new SqlCommand();
		command->Command("SELECT * FROM TENNER");
		
		/* 相互依赖的对象:命令需要 连接对象对其传输 */
		command->SetConnection(connection);
	}
};

??先不考虑抽象工厂的问题,为了文章具有通读性,先对其解决第一个问题:

  • 上面函数中是写了SqlServer的数据库操作过程,如果后面要兼容MySQL或者Oracle呢?

2. 第一部优化

?兼容各种数据库

/* 数据库操作的两个基类 */
class DBConnection
{
public:
	virtual DBConnection()=0;
};
class DBCommand
{
public:
	virtual DBCommand()=0;
};

下面是一种数据库,另外种类的类似,就不列出来了.

/* SqlServer数据库 */
class SqlDBConnection : public DBConnection
{
public:
	virtual DBConnection(){}//仍可保留虚函数
};
class SqlDBCommand : public DBCommand
{
public:
	virtual DBCommnd(){}
};

这时上面的函数就可以这样使用:

vector<EmployeeInfo> GetEmployee()
	{
		//SqlConnect *connection = new SqlConnection();
		DBConnect *connection = new SqlConnection();
		connection->ConnectNet("ip:192.168.0.1");
		//SqlCommand *command = new SqlCommand();
		DBCommand *command = new SqlCommand();
		command->Command("SELECT * FROM TENNER");
		
		command->SetConnection(connection);
	}

??这样我们发现所作的优化好像并没有什么,还存在问题,创建了具体的对象,严重耦合.

3. 使用工厂优化

首先创建连个工厂的基类,声明构建对象的纯虚函数:

class DBConnectFactory
{
public:
	virtual DBConnection *DBConnectObjCreate() = 0; 
};
class DBCommandFactory
{
public:
	virtual DBCommand *DBCommandObjFactory() = 0; 
};

针对一种数据库,构建自己的工厂

class SqlConnectFactory : public DBConnectFactory
{
public:
	virtual DBConnection *DBConnectObjCreate()
	{
		return new SqlDBConnection();
	}
};
class SqlCommandFactory : public DBCommandFactory
{
public:
	virtual DBCommand *DBCommandObjCreate()
	{
		return new SqlDBCommand();
	}
};

此时,我们最开始的函数就可以这样写

class EmployeeDB
{
public:
	DBConnectFactory *dbConnectFact;
	DBCommandFactory *dbCmdFact;
public:
	vector<EmployeeInfo> GetEmployee()
	{
		DBConnect *connection = new SqlConnection();
						修改  = dbConnectFact->DBConnectObjCreate();
		connection->ConnectNet("ip:192.168.0.1");
	
		DBCommand *command = new SqlCommand();
					修改   = dbCmdFact->DBCommandObjCreate();
		command->Command("SELECT * FROM TENNER");
		
		command->SetConnection(connection);
	}
}

还存在问题吗?答案为是。
为什么,因为有两个工厂,如果传进来的两个工厂的子类对象不是同一个数据库类型,就无法兼容。
比如传进来的是Oracle的Connect工厂,但却是MySql的Command工厂,问题是显而易见的。

4. 继续优化

??从工厂入手,也很简单,把工厂合为一个,只是合并。

class DBOptFactory
{
public:
	virtual DBConnection *DBConnectObjCreate() = 0; 
	virtual DBCommand *DBCommandObjFactory() = 0; 
};

这里实现具体工厂也需要合并:

class SqlConnectFactory : public DBConnectFactory
{
public:
	virtual DBConnection *DBConnectObjCreate()
	{
		return new SqlDBConnection();
	}
	virtual DBCommand *DBCommandObjCreate()
	{
		return new SqlDBCommand();
	}
};

如此以来,最终的代码如下:

```cpp
class EmployeeDB
{
public:
	DBOptFactory *dbOptFact;
public:
	vector<EmployeeInfo> GetEmployee()
	{
		DBConnect *connection = new SqlConnection();
						修改  = dbOptFact->DBConnectObjCreate();
		connection->ConnectNet("ip:192.168.0.1");
	
		DBCommand *command = new SqlCommand();
					修改   = dbOptFact->DBCommandObjCreate();
		command->Command("SELECT * FROM TENNER");
		
		command->SetConnection(connection);
	}
}

?这是什么,这相当于嵌套了两层的多态。
来到这里,就需要解释一下,抽象工厂中的抽象是什么含义:
??多态就是要实现抽象,抽象工厂就是一种不止生产一种具体类型对象的工厂,各种对象都可以生产。所以说名为组合工厂更合适.

在这里插入图片描述

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-24 00:37:48  更:2022-03-24 00:41:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 16:07:58-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码