抽象工厂是一种创建型模式,是为了解决实例化时所带来的问题。
我们先来看看是什么问题,有的时候我们会遇到这种情况,我们需要一系列的对象。举个例子,有一系列BMW汽车零部件的对象:轮子bmwwheel,油箱bmwoilbox,在一个管理函数中调用它们,代码如下
class BMWWheel
{
public BMWWheel(){};
}
class BMWOilbox
{
public BMWOilbox(){};
}
public void Manage()
{
BMWOilbox oilbox = new BMWOilbox();
BMWWheel wheel = new BMWWheel();
}
如果现在需求变了,我们要用大众一汽BORA的零件,不用BMW的,那么我们除了要再加上相应的零件对象外还要将Manage函数中的对象更改为BORA的零件对象。
那这时发现new会带来了一些问题:实现依赖,不能应对具体实例化类型的变化。
如何解决这类问题呢?封装变化点。(没有变化的就不需要封装)
工厂模式的缘起:
1、变化点在“对象创建”,因此就封装“对象创建”
2、面向接口编程
简单工厂问题:
1、不能应对“不同系列对象”的变化。如:我们要在上面的代码中加上其他的对象就不能很好的应对了
2、使用面向对象国内的技术来封装变化点
动机:在软件系统中,经常面临着“一系列相互依赖的对象”的创建工作;同时,由于需求的变化,往往存在更多系列对象的创建工作。面对这种问题,我们想绕过常规的对象创建方法,提供一种“封装机制”来避免客户程序和这种“多系列具体对象创建工作”的紧耦合。
对于“紧耦合”,我原来是不喜欢这个词的,但是今天明白了,不是程序紧耦合不好,而是面对频繁变化的需求,紧耦合会使程序的编写变得很吃力。如果面对一个不变的需求,松耦合和紧耦合在代码编写上应该是没什么区别的。
《设计模式》中解释这种模式的意图是:提供一个接口,让该接口负责创建一系列“相关或者相互依赖的对象”,无需指定他们的具体类。
下面我们来看看如何使用抽象工厂模式完成对这种变化的封装:
首先我们的需求是BMW的车轮和油箱,当然他们要继承各自的基类,代码如下
public class Test{
public static void main(String[] args) {
AbstractFactory factory = null;
factory = new BMWFactory();
factory.CreatWheel();
System.out.println("\n");
factory.CreatOilBox();
System.out.println("\n");
}
}
//抽象轮子
abstract class AbstractWheel {
public AbstractWheel(){}
}
//抽象邮箱
abstract class AbstractOilBox{
public AbstractOilBox(){}
}
//宝马轮子,继承自抽象轮子
class BMWWheel extends AbstractWheel{
public BMWWheel(){
System.out.println("Create a BMWwheel");
}
}
//宝马邮箱,继承自抽象邮箱
class BMWOilbox extends AbstractOilBox{
public BMWOilbox(){
System.out.println("Create a BMWOilbox");
}
}
//抽象工厂
abstract class AbstractFactory{
abstract public AbstractWheel CreatWheel();
abstract public AbstractOilBox CreatOilBox();
}
//宝马工厂
class BMWFactory extends AbstractFactory{
public AbstractWheel CreatWheel(){
return new BMWWheel();
}
public AbstractOilBox CreatOilBox(){
return new BMWOilbox();
}
}
显示结果:
Create a BMWwheel
Create a BMWOilBox
现在我们想不用BMW的零件,用BORA的零件了,先写一些BORA零件的类:
class BORAWheel extends AbstractWheel{
public BORAWheel() {
System.out.println("Create a BORAWheel");
}
}
class BORAOilBox:AbstractOilBox {
public BORAOilBox() {
System.out.println("Create a BORAOilBox");
}
}
然后我们再创建BORA零件的工厂:
class BORAFactory extends AbstractFactory {
public AbstractWheel CreatWheel() {
return new BORAWheel();
}
public AbstractOilBox CreatOilBox(){
return new BORAOilBox();
}
}
再来看看如何在Main函数中修改使其调用BORA的零件;我们只要在将Main中的factory对象实例化为BORA的工厂BORAFactory就可以了:
public static void main(String[] args) {
AbstractFactory factory = null;
factory = new BORAFactory();
factory.CreatWheel();
factory.CreatOilBox();
}
结果如下:
Create a BORAWheel
Create a BORAOilBox
Abstract Factory模式的几个要点:
1、如果没有应对“多系列对象构建”的需求变化,则没有必要使用Abstract Factory模式。
2、“系列对象”指的是这项对象之间有相互依赖、或作用的关系。
3、Abstract Factory模式主要在于应对“新系列”的需求变动。缺点是难以应对“新对象”的需求变动。这一点应该注意,就像前面说的,如果我们现在要在加入其他系列的类,代码的改动会很大。
4、Abstract Factory模式经常和Factory Method模式共同组合来应对“对象创建”的需求变化。
修改自:http://www.cnblogs.com/kid-li/archive/2006/04/22/382412.html
分享到:
相关推荐
**抽象工厂模式(Abstract Factory Pattern)是创建型设计模式之一,它提供了一种创建对象的接口,使得子类可以决定实例化哪一个类。这种类型的设计模式属于类的创建模式。** 在C#中,抽象工厂模式的核心在于抽象...
抽象工厂模式是面向对象设计模式中的一个创建型模式,它为创建一组相关或相互依赖的对象提供了一个接口,而无需指定它们的具体类。在C#中,这种模式的应用可以帮助我们实现跨平台、跨环境的代码,使得系统更具扩展性...
抽象工厂模式是面向对象设计模式中的创建型模式之一,它为创建一组相关或相互依赖的对象提供了一个统一的接口,使得客户端无需关注这些对象的具体实现细节。在C#中,抽象工厂模式的应用尤为广泛,尤其在多平台开发...
抽象工厂模式(Abstract Factory)是一种创建型设计模式,用于提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类。这种模式的关键在于,它允许客户端代码与具体的实现细节解耦,使得添加新的产品...
首先,我们来详细解释抽象工厂模式的基本概念。抽象工厂模式包含四个主要角色: 1. **抽象工厂(Abstract Factory)**:这是接口或者抽象类,定义了创建一系列相关或相互依赖对象的接口,而不涉及它们具体的类。 2. ...
Abstract_Factory抽象工厂Abstract_Factory抽象工厂Abstract_Factory抽象工厂Abstract_Factory抽象工厂
抽象工厂模式是设计模式中的一种创建型模式,其主要目的是为了解耦客户端代码与具体产品的实现。在软件工程中,当系统需要根据不同的平台、环境或者配置产生一系列相关对象,而这些对象之间的关系又非常复杂时,抽象...
1. **模式结构**:抽象工厂模式通常包括抽象工厂接口(AbstractFactory),具体工厂类(ConcreteFactory),抽象产品接口(Product)以及具体产品类(ConcreteProduct)。抽象工厂定义了创建产品的方法,而具体工厂...
抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,它提供了一种创建对象集合的接口,而无需指定具体的产品类型。这种模式适用于当系统需要在不同平台或环境中创建一组相关或相互依赖的对象时,而这些...
### 抽象工厂模式(Abstract Factory Pattern) #### 引入 在探讨抽象工厂模式之前,我们先回顾一下之前介绍过的简单工厂模式与工厂方法模式。这两种模式主要关注于解决对象创建过程中“new”操作的问题,使得创建...
在软件工程中,抽象工厂模式经常用于框架和库的开发,它可以用来封装一系列相关或相互依赖的对象的创建,使得客户端代码可以在不关心具体实现的情况下使用这些对象。这样,当需要更换不同的产品族时,只需要替换对应...
此外,抽象工厂模式还可以与其他设计模式结合使用,比如工厂方法模式(Factory Method Pattern),在某些情况下,可以将抽象工厂模式的抽象工厂类设计为工厂方法模式,让子类决定实例化哪一个类。同时,抽象工厂模式...
抽象工厂模式是设计模式中的一种创建型模式,它提供了一个创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类。在Java编程中,这种模式通常用于隔离客户端与具体实现之间的耦合,使得系统可以在不修改代码...
设计模式抽象工厂模式(AbstractFactory)源代码
抽象工厂模式是设计模式中的一种结构型模式,它在C++编程中有着广泛的应用。这个模式主要用于创建一系列相关的对象,而无需指定它们的具体类。在本文中,我们将深入探讨抽象工厂模式的概念、工作原理以及在C++中的...
抽象工厂模式是工厂方法模式的进一步扩展,它提供了一个创建一系列相关或相互依赖对象的接口,而无需指定它们的具体类。这在处理不同平台或环境下的产品族时非常有用。在Java中,我们可以通过创建抽象工厂类和具体...
抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,它提供了一种在不指定具体类的情况下创建一系列相关或相互依赖对象的接口。这个模式使得客户端代码与具体产品的实现解耦,从而提高了系统的灵活性和...
抽象工厂模式是设计模式中的一种创建型模式,它提供了一种创建对象集合的接口,而无需指定具体的类。这种模式允许系统独立于如何创建、组合和表示产品对象的细节进行设计,为产品族(一组相关或相互依赖的对象)提供...
在C#中实现抽象工厂模式(Abstract Factory Pattern)涉及定义一个抽象工厂接口,该接口声明用于创建抽象产品的方法。然后,为每个具体产品族实现一个具体工厂,这些工厂提供创建具体产品的实现。最后,客户端代码...