1.3抽象工厂模式

简介: 1.概念:提供一个创建一系列相关对象的接口,而无需指定具体的类。   用简单工厂改进抽象工厂实例: public class DataAccess  {      private const readonly string dbstr="MSSQL";        public ...
1.概念:提供一个创建 一系列相关对象的接口,而无需指定具体的类。
 
用简单工厂改进抽象工厂实例:
public class DataAccess 
{
     private const readonly string dbstr="MSSQL";
 
     public static IUser CreateUser()
     {
          IUser user = null;
          switch (dbstr)
          {
               case "MSSQL":
                user = new SqlServerUser();  //这里的实例化是写死在程序里面
               break;
               case "ORACLE":
                user = new OracleServerUser();//利用反射,利用字符串来实例化对象
               break;
               default:
          }
          return user;
     }
 
      //出现坏味道
      public static IDepartment CreateDepartment()
     {
          IDepartment department = null;
          switch (dbstr)
          {
               case "MSSQL":
               department = new SqlServerDepartment();
               break;
               case "ORACLE":
               department = new OracleServerDepartment();
               break;
               default:
          }
          return department;
     }
}
 
IUser user=DataAccess.CreateUser(); //直接得到数据库实例,而不存在任何依赖
user.Insert(user);
 
问题:如果频繁增加数据库,只能修改switch的case了
 
解决:
(1).利用反射+抽象工厂的模式 进行改造
 
public class DataAccess 
{
     private const readonly string db="MSSQL";
     private const readonly string _assemblyName="程序集名称";
 
     public static IUser CreateUser()
     {
          string className = _assemblyName+"."+db+"User";
          return (IUser) Assembly.Load(assemblyName).CreateInstance(className);
     }
}
 
(2).利用反射+配置文件 进行改造
<configuration>
     <appsettings>     
          <add key="DB"  value="MSSQL"/>
     </appsettings>
</configuration>
 
public class DataAccess 
{
     private const readonly string db=ConfigurationManager.AppSettings("DB");
     private const readonly string _assemblyName="程序集名称"; 
}
 
从这个角度来说,反射可以很好解决if,switch带来的耦合。
目录
相关文章
|
Kubernetes 容器
要获取ACK(阿里云容器服务)集群中的Deployment
要获取ACK(阿里云容器服务)集群中的Deployment【1月更文挑战第8天】【1月更文挑战第40篇】
207 4
Java面向对象(二)
Java面向对象(二)
|
存储 数据采集 消息中间件
美团买菜基于 Flink 的实时数仓建设
美团买菜实时数仓技术负责人严书,在 Flink Forward Asia 2022 实时湖仓专场的分享。
7287 0
美团买菜基于 Flink 的实时数仓建设
|
存储 编译器 程序员
c语言入门篇
c语言入门篇
120 0
|
前端开发 Java C++
【面试题精讲】JVM-打破双亲委派机制-自定义类加载器
【面试题精讲】JVM-打破双亲委派机制-自定义类加载器
|
数据采集 JSON JavaScript
node-spider:node实践简单的爬虫
node-spider:node实践简单的爬虫
235 0
|
存储 城市大脑 安全
郑州:如何”变身“一座全场景数字化运营的城
基于阿里云的IDaaS能力体系,郑州建立起以“自然人”为中心的统一身份认证平台,并接入业务中台和数据中台。
郑州:如何”变身“一座全场景数字化运营的城
编程题
7.一个采用查询方式输出数据的 I/O 接口中,8 位数据端口地址为 2000H,1 位 状态端口地址为 2002H,外设状态位用 D0 传送,高电平表示数据准备好。设 1000 个字节数据存在内存 BUFFER 为首地址的缓冲区中,写出查询方式输出 1000 个 字节数据的程序段。 LEA SI,BUFFER MOV CX,1000 P: MOV DX,2002H L: IN AL,DX TEST AL,01H JZ L MOV DX,2000H MOV AL,[SI] OUT DX,AL INC SI LOOP P HLT 8.编写完整程序,将键盘输入的小写字母转换成大写字母并输出显示,直
225 0
|
搜索推荐
码上公益|7天解决多年档案管理难题
爱心极客用数字技术,助力公益组织档案管理高效化、精细化,守护每一份爱心。
465 0
码上公益|7天解决多年档案管理难题
|
人工智能 自然语言处理 达摩院
58.3万笔/秒!看阿里的黑科技
11月11日0点刚过26秒,天猫双11的订单创建峰值就达到58.3万笔/秒,阿里云又一次扛住全球最大规模流量洪峰!58.3万笔/秒,这一数字是2009年第一次天猫双11的1457倍。数字的背后,隐藏着阿里巴巴很多不为人知的技术创新和突破,乃至世界顶尖技术。今天,阿里妹就来和大家分享阿里巴巴天猫双11背后的黑科技!
48183 0
58.3万笔/秒!看阿里的黑科技