- 浏览: 592519 次
- 性别:
- 来自: 福建
文章分类
最新评论
-
18335864773:
用 pageoffice 吧. http://www.zhuo ...
使用Jacob输出word文档 -
dick1305:
很好,谢谢分享。
XFire创建WebService实例 -
wd530141534:
<c:if test="${ReleaseRe ...
Axis2创建WebService实例 -
wd530141534:
if(result != null && re ...
Axis2创建WebService实例 -
wd530141534:
String printerIp = req.getRemot ...
Axis2创建WebService实例
抽象工厂模式:提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。
抽象工厂模式是指当有多个抽象角色时,使用的一种工厂模式。抽象工厂模式可以向客户端提
供一个接口,使客户端在不必指定产品的具体的情况下,创建多个产品族中的产品对象。
与工厂方法模式的区别:
抽象工厂模式:
1.多个抽象产品类,每个抽象产品类可以派生出多个具体产品类。
2.一个抽象工厂类,可以派生出多个具体的工厂类。
3.每个具体工厂类可以创建多个具体产品类的实例。
工厂方法模式:
1.一个抽象产品类,可以派生出多个具体产品类。
2.一个抽象工厂类,可以派生出多个具体工厂类。
3.每个具体工厂类只能创建一个具体产品类的实例。
抽象工厂就像工厂,而工厂方法则像是工厂的一种产品生产线
抽象工厂模式实例:
/** * 用户类 */ public class User { private String id; private String name; public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
/** * 用户接口 */ public interface IUser { public void insertUser(User user); public User getUser(String id); }
/** * 用于访问Access的User。 */ public class UserAccess implements IUser { public User getUser(String id) { System.out.println("在Access中根据ID得到User表一条记录。"); return null; } public void insertUser(User user) { System.out.println("在Access中给User表添加一条记录。"); } }
/** * 用于访问SqlServer的User。 */ public class UserSqlServer implements IUser { public User getUser(String id) { System.out.println("在SqlServer中根据ID得到User表一条记录。"); return null; } public void insertUser(User user) { System.out.println("在SqlServer中给User表添加一条记录。"); } }
/** * 部门类 */ public class Department { private String id; private String name; public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
/** * 部门接口 */ public interface IDepartment { public void insertDepartment(Department department); public Department getDepartment(String id); }
/** * 用于访问Access的Department。 */ public class DepartmentAccess implements IDepartment { public Department getDepartment(String id) { System.out.println("在Access中根据ID得到Department表一条记录。"); return null; } public void insertDepartment(Department department) { System.out.println("在Access中给Department表添加一条记录。"); } }
/** * 用于访问SqlServer的Department。 */ public class DepartmentSqlServer implements IDepartment { public Department getDepartment(String id) { System.out.println("在SqlServer中根据ID得到Department表一条记录。"); return null; } public void insertDepartment(Department department) { System.out.println("在SqlServer中给Department表添加一条记录。"); } }
/** * 定义一个创建访问User表和部门表对象的抽象的工厂接口 */ public interface IFactory { // 创建用户 public IUser createUser(); // 创建部门 public IDepartment createDepartment(); }
/** * 实现IFactory接口,实例化AccessUser和AccessDepartment。 */ public class FactoryAccess implements IFactory{ public IDepartment createDepartment() { return new DepartmentAccess(); } public IUser createUser() { return new UserAccess(); } }
/** * 实现IFactory接口,实例化SqlServerUser和SqlServerDepartment。 */ public class FactorySqlServer implements IFactory{ public IDepartment createDepartment() { return new DepartmentSqlServer(); } public IUser createUser() { return new UserSqlServer(); } }
public class Main { public static void main(String[] args) { // 用户 User user = new User(); // 部门 Department department = new Department(); // 访问SqlServer数据库(访问Access只要改为new FactoryAccess()). IFactory factory = new FactorySqlServer(); // 操作用户表 IUser iu = factory.createUser(); iu.insertUser(user); iu.getUser("1"); // 操作部门表 IDepartment id = factory.createDepartment(); id.insertDepartment(department); id.getDepartment("1"); } }
用简单工厂改进抽象工厂:抛弃了IFactory,FactorySqlServer,FactoryAccess三个工厂类.
不足之处:如果需要增加Oracle数据库,应需要在每个方法的switch中添加case处理。
/** * 数据库枚举类 */ public enum DataBaseEnum { SqlServer,Access; }
public class DataAccess { // 数据库名称(可替换成Access) private static final DataBaseEnum dataBase = DataBaseEnum.SqlServer; // 根据不同的数据库操作用户表 public static IUser createUser(){ IUser iUser = null; // 由于DB的事先设置,此处可根据选择实例化出相应的对象 switch(dataBase){ case SqlServer: iUser = new UserSqlServer(); break; case Access: iUser = new UserAccess(); break; } return iUser; } // 根据不同的数据库操作部门表 public static IDepartment createDepartment(){ IDepartment iDepartment = null; // 由于DB的事先设置,此处可根据选择实例化出相应的对象 switch(dataBase){ case SqlServer: iDepartment = new DepartmentSqlServer(); break; case Access: iDepartment = new DepartmentAccess(); break; } return iDepartment; } }
简单工厂类的改进:采用反射机制解决简单工厂中switch分支添加case处理的修改变动。
也可采用配置文件和反射技术进行改进。
public class DataAccessReflect { // 此处可改为AccessUser(访问Access数据库)或OracleUser(访问oracle数据库) private static final String userClassName = "com.design." + "factory.abstractFactory.UserSqlServer"; private static final String departClassName = "com.design." + "factory.abstractFactory.DepartmentSqlServer"; // 根据不同的数据库操作用户表 public static IUser createUser(){ IUser iUser = null; try { // 利用反射实例化指定的对象 iUser = (IUser)Class.forName(userClassName).newInstance(); } catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } return iUser; } // 根据不同的数据库操作部门表 public static IDepartment createDepartment(){ IDepartment iDepartment = null; try { // 利用反射实例化指定的对象 iDepartment = (IDepartment)Class .forName(departClassName).newInstance(); } catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } return iDepartment; } }
public class Main { public static void main(String[] args) { // 用户 User user = new User(); // 部门 Department department = new Department(); // 操作用户表(直接得到实际的数据库访问实例,而不存在任何依赖) IUser iu = DataAccess.createUser(); iu.insertUser(user); iu.getUser("1"); // 操作部门表(直接得到实际的数据库访问实例,而不存在任何依赖) IDepartment id = DataAccess.createDepartment(); id.insertDepartment(department); id.getDepartment("1"); //**************改进后的反射机制调用********************* IUser iuReflect = DataAccessReflect.createUser(); iuReflect.insertUser(user); iuReflect.getUser("1"); // 操作部门表(直接得到实际的数据库访问实例,而不存在任何依赖) IDepartment idReflect = DataAccessReflect.createDepartment(); idReflect.insertDepartment(department); idReflect.getDepartment("1"); } }
发表评论
-
设计模式的一些相关原则
2011-06-23 17:01 1376面向对象的三大特性 ... -
访问者模式
2011-06-23 16:31 1772访问者模式:表示一个作用于某对象结构中的各元素的操作。它使 ... -
模板方法模式
2011-06-23 11:16 1170模板方法模式:定义一个操作中的算法的骨架,而将一些步骤迟到 ... -
策略模式
2011-06-23 10:29 1109策略模式: 定义了算 ... -
状态模式
2011-06-22 16:34 1270状态模式:当一个对象的内在状态改变时允许改变其行为,这个对象 ... -
单例模式
2011-06-22 15:30 1259单例模式:保证一个类仅有一个实例,并提供一个访问它的全局访问点 ... -
代理模式
2011-06-22 15:14 1007代理模式:为其它对象提供一种代理,以控制对这个对象的访问。 ... -
原型模式
2011-06-22 14:36 1074原型模式:用原型实例指定创建对象的种类,并且通过拷贝这些原型 ... -
观察者模式
2011-06-17 10:46 1243观察者模式(发布-订 ... -
备忘录模式
2011-06-16 10:58 1034备忘录模式:在不破坏封装性的前提下,捕获一个对象的内部状态 ... -
中介者模式
2011-06-16 10:10 1860中介者模式:用一个中介对象来封装一系列的对象交互,从而降低 ... -
迭代器模式
2011-06-15 11:17 2879迭代器模式:提供一种方法顺序访问一个聚合对象中各个元素,而又不 ... -
解释器模式
2011-06-15 10:44 1264解释器模式:给定一个语言,定义它的文法的一种表示。并定义一个 ... -
享元模式
2011-06-14 11:22 1085享元模式:运用共享技术有效地支持大量细粒度的对象。 ... -
简单工厂与工厂方法模式
2011-06-13 16:38 1136简单工厂模式:由一个工厂对象决定创建出哪一种产品类的实例。 ... -
外观模式
2011-06-13 15:08 1079外观模式:为子系统中的一组接口提供一个一致的界面,此模式定义了 ... -
命令模式
2011-04-21 17:40 1212命令模式:将一个请求 ... -
桥接模式
2011-04-20 21:24 1375桥接模式:将抽象部分与他的实现部分分离,使它们都可以独立地变化 ... -
职责链模式
2011-04-20 21:23 1279职责链模式:使多个对 ... -
装饰模式
2010-09-01 21:35 1214装饰模式: 1. 动态地给一个对象添加一些额外的职责,就 ...
相关推荐
工厂模式分为三种主要类型:简单工厂模式、工厂方法模式和抽象工厂模式。 1. **简单工厂模式** 简单工厂模式是最简单的工厂模式实现,它提供一个静态方法或者类来创建对象,这个类通常被称为“工厂”。用户只需要...
抽象工厂模式是设计模式中的一种创建型模式,它提供了一种创建对象集合的接口,而无需指定具体的类。这种模式允许系统独立于如何创建、组合和表示产品对象的细节进行设计,为产品族(一组相关或相互依赖的对象)提供...
在软件设计模式中,工厂模式是一组非常基础且实用的设计模式,主要分为简单工厂模式、工厂方法模式和抽象工厂模式。这些模式都是为了解决对象创建的问题,通过封装对象的创建过程,使得代码更加灵活,易于扩展和维护...
java设计模式 抽象工厂模式详解 一张图让你彻底明白抽象工厂模式
工厂方法模式和抽象工厂模式是两种常见的设计模式,它们都属于创建型模式,用于解决对象的创建问题。在软件设计中,这两种模式都是用来隔离对象的创建和使用,以提高系统的灵活性和可扩展性。 首先,工厂方法模式的...
设计模式 - 抽象工厂模式 抽象工厂模式是一种创建型设计模式,它提供了一种方式来创建一组相关或相互依赖的对象,而不需要指定具体的类。该模式允许客户端使用抽象的接口来创建一组相关的产品,而不需要关系实际...
本文将探讨三个重要的设计模式:抽象工厂模式、工厂方法模式以及策略模式,并结合一个实际的场景——手机加工厂,来具体阐述它们的应用。 首先,我们来看**抽象工厂模式**。这个模式主要用于创建相关或依赖对象的...
抽象工厂模式是软件工程中常用的一种创建型设计模式,它的核心思想是为创建一组相关或相互依赖的对象提供一个接口,而不需要指定它们具体的类。在Java中,抽象工厂模式被广泛应用,它有助于整合代码,提高系统的可...
抽象工厂模式是设计模式中的一种创建型模式,它提供了一个创建对象族的接口,而无需指定它们的具体类。在.NET开发中,这种模式常用于实现多数据库连接,比如连接到MySQL、SQL Server或Oracle等不同的数据库系统。...
抽象工厂模式是一种设计模式,属于创建型模式,它提供了一种创建对象族的接口,而无需指定其具体的类。这种模式的关键在于“族”,它表示一系列相关或相互依赖的对象。在不指定具体类的情况下,抽象工厂模式使得...
抽象工厂模式是设计模式中的一种创建型模式,它提供了一种创建对象族的接口,而无需指定具体的类。在C#编程中,这种模式经常被用于实现跨平台或跨框架的代码,使得代码与具体实现解耦,提高系统的灵活性和可扩展性。...
### 抽象工厂模式简介与应用实例 #### 一、抽象工厂模式定义 抽象工厂模式是一种创建型设计模式,它能够让我们从一个公共接口中创建一系列相关或相互依赖的对象,而无需指定它们的具体类。该模式的核心在于提供了...
抽象工厂模式是设计模式中的一种创建型模式,它提供了一种创建对象族的接口,而无需指定其具体的类。这种模式的关键在于“族”,即一系列相关的对象。在抽象工厂模式中,我们创建一个抽象工厂接口,然后为每一种具体...
在这个压缩包中,包含了三种工厂模式的C++实现:简单工厂模式、工厂方法模式以及抽象工厂模式。让我们一一探讨这些模式。 1. 简单工厂模式: 简单工厂模式是一种静态工厂方法,它提供一个公共的工厂类来创建对象。...
抽象工厂模式是设计模式中的一种,它提供了一个创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类。在软件工程中,当系统需要在运行时选择不同的产品族时,或者想要隔离具体产品的实现细节时,抽象工厂...
抽象工厂模式是设计模式中的一种结构型模式,它提供了一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。在Android开发中,这种模式尤其有用,因为Android平台有多种设备,每种设备可能有不同的UI...
抽象工厂模式是设计模式中的一种,它属于创建型模式,主要解决的是当系统有多个产品族,而每个产品族又有多个具体产品时,如何组织代码的问题。在Java中,抽象工厂模式提供了一种创建对象组的方式,使得这些对象属于...
抽象工厂模式是一种面向对象的设计模式,它提供了一个创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类。在C#中,这种模式经常用于软件工程中的框架设计,允许系统独立于具体产品的实现进行扩展和修改。...
在软件设计模式中,工厂方法模式(Factory Method Pattern)和抽象工厂模式(Abstract Factory Pattern)是两种常用的创建型设计模式,它们都属于“工厂”家族,但有着不同的应用场景和目标。 工厂方法模式的核心...
抽象工厂模式是一种创建型设计模式,它提供了一种创建对象族的方法,而无需指定它们的具体类。在计算器的实现中,这个模式可以帮助我们构建不同类型的计算器,比如简单计算器、科学计算器等,而无需修改现有代码。 ...