首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件开发 >

Java软件工程师从笨鸟到初学者之(三十二)大话设计模式之设计模式分类和三种工厂模式

2012-06-28 
Java程序员从笨鸟到菜鸟之(三十二)大话设计模式之设计模式分类和三种工厂模式?设计模式分类首先先简单说一

Java程序员从笨鸟到菜鸟之(三十二)大话设计模式之设计模式分类和三种工厂模式

?

设计模式分类

首先先简单说一下设计模式的分类设计模式可以分为三大类,分别是创建型设计模式、行为型设计模式以及结构型设计模式。

创建型的设计模式:单例模式(Singleton)、构建模式(Builder)、原型模式(Prototype)、抽象工厂模式(Abstract?Factory)、工厂方法模式(Factory?Method)

行为设计模式:策略模式(Strategy)、状态模式(State)、责任链模式(Chain?of?Responsibility)、解释器模式(Interpreter)、命令模式(Command)、观察者模式(Observer)、备忘录模式(Memento)、迭代器模式(Iterator)、模板方法模式(Template?Method)、访问者模式(Visitor)、中介者模式(Mediator)

结构型设计模式:装饰者模式(Decorator)、代理模式(Proxy)、组合模式(Composite)、桥连接模式(Bridge)、适配器模式(Adapter)、蝇量模式(Flyweight)、外观模式(Facade)

? 简单工厂模式

??????从设计模式的类型上来说,简单工厂模式是属于创建型模式,又叫做静态工厂方法(StaticFactory?Method)模式,但不属于23种GOF设计模式之一。简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例。简单工厂模式是工厂模式家族中最简单实用的模式,可以理解为是不同工厂模式的一个特殊实现。?

简单工厂模式的一般结构,如图所示:

Java软件工程师从笨鸟到初学者之(三十二)大话设计模式之设计模式分类和三种工厂模式

?

 ???简单工厂模式存在三个组成部分,参考《Java与模式》一书,对应于三个不同的角色:

l?工厂角色

l?抽象产品角色

l?具体产品角色

  ?其实角色这个词用的比较确切,能够让我们理解到,每个角色的不是单纯地指一个类,可能是一组类所构成了这个角色。下面对三个角色进行描述:

1.?工厂角色

  工厂角色负责产品的生产工作。在简单工厂模式中,工厂类是一个具体的实现类,在系统设计中工厂类负责实际对象的创建工作。

  工厂类(Factory)的特点是:它知道系统中都存在哪些能够创建对象的具体类(ConcreteProduct),也知道该如何将创建的对象,以某种能够屏蔽具体类实现细节的方式(AbstractProduct)提供给所需要的其他角色来使用该对象提供的数据和服务。

2.抽象产品角色

  抽象产品角色是具体的产品的抽象。抽象就是将产品的共性抽取出来,可以直接暴露给客户端(需要使用具体产品的角色),对所有的客户端来说,从工厂中直接获取到的原始产品的外部形态都是相同的,没有任何的差别,包括数据和服务。这也就是说,具体客户端应该“秘密”掌握着某一个或一些具体产品的详细资料(具体产品类型、数据和服务),然后根据具体客户端(任何一个需要使用某种具体产品的数据和服务的实现类)需要什么样的附加数据和服务,进行类类型转换后,通过借助于对应的具体产品对象来完成其职责。

  抽象产品角色,在实际系统中可以定义为接口或者抽象类。

3.具体产品角色

  具体产品实现类一定是抽象产品类的实现或扩展。为了保证工厂类能够创建对象,工厂类需要知道具体产品的创建方式,这就涉及到具体产品类所提供的构造方法,以便,可能工厂类会向客户端提供具体创建服务所需要的数据。例如:某个产品类需要通过一个账号才能构造其实例,所以工厂类必须根据它的创建需求,为客户端提供一个带账号参数的生产方法,才能创建该具体产品类的对象。

  也就是说,工厂类依赖于具体产品实现类。同样,客户端类是依赖于工厂类的。

通过上述三个角色的描述,我们应该能够了解,系统中哪些类能够胜任上述的三个角色,并通过各类之间的关系,通过工厂模式来实现系统或者某个模块。在实际的设计过程中,可能不存在完全与上述基本简单工厂模式完全适应的,需要根据具体的需求来调整简单工厂模式的应用。只要能够实现系统的良好设计,有时候变化才能满足需要。

下面用一个简单的例子来说明一下,给大家加深一下印象(例子来自于网络):

?

我们在不改变产品类(“足球运动员”类和“篮球运动员”类)的情况下,写一下工厂方法模式的例子:

图中的BmwCar和BenzCar就是两个产品树(产品层次结构);而如图所示的BenzSportsCar和BmwSportsCar就是一个产品族。他们都可以放到跑车家族中,因此功能有所关联。同理BmwBussinessCar和BenzSportsCar也是一个产品族。

抽象工厂模式中的有以下的四种角色:

抽象工厂(Abstract?Factory)角色:担任这个角色的是工厂方法模式的核心,它是与应用系统商业逻辑无关的。?

具体工厂(Concrete?Factory)角色:这个角色直接在客户端的调用下创建产品的实例。这个角色含有选择合适的产品对象的逻辑,而这个逻辑是与应用系统的商业逻辑紧密相关的。

?抽象产品(Abstract?Product)角色:担任这个角色的类是工厂方法模式所创建的对象的父类,或它们共同拥有的接口。

具体产品(Concrete?Product)角色:这个角色用以代表具体的产品。

?Abstract?Factory模式的结构:

Java软件工程师从笨鸟到初学者之(三十二)大话设计模式之设计模式分类和三种工厂模式

抽象工厂模式就相当于创建实例对象的new,由于经常要根据类生成实例对象,抽象工厂模式也是用来创建实例对象的,所以在需要新的事例对象时便可以考虑是否使用工厂模式。虽然这样做可能多做一些工作,但会给你系统带来更大的可扩展性和尽量少的修改量。

举例来说:生产餐具和相应食物的工厂,有两个车间,其中一个车间用以生产餐具,一个车间用以生产相应的食物。

当消费者消费时,只需要向相应的具体工厂请求具体餐具和具体食物便可以使用餐具消费食物。

使用UML图表示以上的描述如下:

Java软件工程师从笨鸟到初学者之(三十二)大话设计模式之设计模式分类和三种工厂模式

?

图1抽象工厂与具体工厂

Java软件工程师从笨鸟到初学者之(三十二)大话设计模式之设计模式分类和三种工厂模式

图2抽象餐具与具体餐具(生产车间)

Java软件工程师从笨鸟到初学者之(三十二)大话设计模式之设计模式分类和三种工厂模式

?

图3抽象食物与具体食物

注:图中厨房单词写错了:kitchen

每个具体工厂生产出来的具体产品根据不同工厂的不同各不相同,但是客户使用产品的方法是一致的。比如客户在得到餐具和食物之后,两者的搭配是正确的(使用汤匙喝牛奶,使用刀子切面包)。

在本例子中有3个具体工厂AKitchen,?BKitchen,?BKitchen,分别生产牛奶和汤匙、面包和刀、肉和叉子。牛奶、面包和肉都实现了食物接口。汤匙、刀和叉子都实现了餐具接口。

抽象工厂的接口定义如下所示;

????

}??


在以下情况下应当考虑使用抽象工厂模式:

·?一个系统不应当依赖于产品类实例如何被创建、组合和表达的细节,这对于所有形态的工厂模式都是重要的。

·?这个系统有多于一个的产品族,而系统只消费其中某一产品族。

·?同属于同一个产品族的产品是在一起使用的,这一约束必须在系统的设计中体现出来。

·?系统提供一个产品类的库,所有的产品以同样的接口出现,从而使客户端不依赖于实现。

更多信息请查看?java进阶网?http://www.javady.com

热点排行