java工厂设计模式课件.ppt
《java工厂设计模式课件.ppt》由会员分享,可在线阅读,更多相关《java工厂设计模式课件.ppt(50页珍藏版)》请在三一办公上搜索。
1、The Factory Pattern(工厂模式),学习问题,随着经济的全球化,一个软件可能要在全球销售。因此,我们设计的软件应该能够通过简单的配置就可以适应不同的国家。本讲所学的知识将能提供一种有助于解决此问题的方法。,对象创建问题,关于new:按照面向抽象的设计原则,我们应该面向接口编程而不是面向实现编程。但是我们每次使用new时,是不是正在违背这一原则呢?,我们想用接口,但却必须建立一个具体类的实例,Duck duck=new MallardDuck(),问题,当你拥有一组相关的具体类时,你常常被迫写出类似下面的代码:Duck duck;If(picnic)duck=new Mallar
2、dDuck();else if(hunting)duck=new DecoyDuck();else if(inBathTub)duck=new RubberDuck();,这样做的原因是直到运行时我们才知道需要实例化那个类。,这样做的后果是如果应用要做变化或扩展,往往要修改这段代码。这使得维护困难并容易引入错误。,问题在哪里?是new的问题吗?,从技术上来说,new并没有任何问题。new是java最基本的部分。真正的问题在于“变化”如果对接口编程,我们可实现与许多“变化”的隔离,因为通过多态机制,你的代码对于实现接口的新类依然适用。但是使用具体类麻烦就来了,因为增加新的具体类时相应代码可能就必
3、须修改。,怎么办呢?,Duck duck=new MallardDuck()上面这段代码所在的模块与MallardDuck模块形成了耦合。,再回忆我们前面提出的面向对象设计的原则,识别应用的变化部分,并将之与固定的部分相分离。,区分变化的部分,下面我们来看一个例子Pizza店,披萨,PizzaStore类中的一段代码-订做pizza,Public Class PizzaStore/Pizza orderPizza()Pizza pizza=new Pizza();pizza.prepare();pizza.bake();pizza.cut();pizza.box();return pizza;
4、/,真希望这是一个抽象类或者接口,可惜抽象类或接口都不能被实例化,而且,我们有许多种pizza,所以我们增加一些代码,来确定合适的pizza种类,然后进行制作。,修改后的代码,Pizza orderPizza(String type)Pizza pizza;if(type.equals(“cheese”)pizza=new CheesePizza();else if(type.equals(“greek”)pizza=new GreekPizza();else if(type.equals(“pepperoni”)pizza=new PepperoniPizza();pizza.prepare
5、();pizza.bake();pizza.cut();pizza.box();return pizza;,根据接受的类型,创建相应的pizza实例,并赋值给实例变量。(注意:各种pizza实现接口Pizza),传递pizza的类型给方法orderPizza,每一种pizza子类型都知道其制作方法,由于市场竞争。,其他pizza店推出了新产品,我们也得增加!例如VeggiePizza。GreekPizza最近不受欢迎,把它从菜单中取消。于是。,改!改!改!,Pizza orderPizza(String type)Pizza pizza;if(type.equals(“cheese”)pizz
6、a=new CheesePizza();else if(type.equals(“greek”)pizza=new GreekPizza();else if(type.equals(“pepperoni”)pizza=new PepperoniPizza();else if(type.equals(“veggie”)pizza=new VeggiePizza();pizza.prepare();pizza.bake();pizza.cut();pizza.box();return pizza;,变与不变,变与不变,Pizza orderPizza(String type)Pizza pizza
7、;if(type.equals(“cheese”)pizza=new CheesePizza();else if(type.equals(“greek”)pizza=new GreekPizza();else if(type.equals(“pepperoni”)pizza=new PepperoniPizza();else if(type.equals(“veggie”)pizza=new VeggiePizza();pizza.prepare();pizza.bake();pizza.cut();pizza.box();return pizza;,这是变化的部分。随着Pizza菜单的变化,
8、这部分要跟着不断地变。,这部分是不变的部分。,分离,Pizza orderPizza(String type)Pizza pizza;if(type.equals(“cheese”)pizza=new CheesePizza();else if(type.equals(“greek”)pizza=new GreekPizza();else if(type.equals(“pepperoni”)pizza=new PepperoniPizza();else if(type.equals(“veggie”)pizza=new VeggiePizza();pizza.prepare();pizza.
9、bake();pizza.cut();pizza.box();return pizza;,把这部分封装在一个只管如何创建pizza的对象中,if(type.equals(“cheese”)pizza=new CheesePizza();else if(type.equals(“greek”)pizza=new GreekPizza();else if(type.equals(“pepperoni”)pizza=new PepperoniPizza();else if(type.equals(“veggie”)pizza=new VeggiePizza();,将创建pizza对象的代码从orde
10、rPizza方法中分离出去,专管制作pizza的对象,我们将专管制作pizza的对象叫做Pizza工厂,Pizza orderPizza(String type)Pizza pizza;pizza.prepare();pizza.bake();pizza.cut();pizza.box();return pizza;,PizzaFactory,要求制作pizza,pizza,这样,orderPizza方法就成为PizaFactory的客户。,Pizza工厂-SimplePizzaFactory,public class SimplePizzaFactory public Pizza creat
11、ePizza(String type)Pizza pizza=null;if(type.equals(“cheese”)pizza=new CheesePizza();else if(type.equals(“pepperoni”)pizza=new PepperoniPizza();else if(type.equals(“veggie”)pizza=new VeggiePizza();return pizza;,Pizza工厂中定义了“生产”pizza的方法。所有客户都可以用它来实例化新的pizza对象,这部分代码就是从orderPizza()方法中抽出来的。和原来的方法一样,也是通过参数
12、确定pizza的种类。,思考一下!,这看来好像我们只是把问题从一个对象推给了另一个对象!这样做有什么好处呢?可以解除客户代码(PizzaStore)与具体Pizza的耦合。SimplePizzaFactory可以有许多个客户,这样,当实现改变时我们只需要修改SimplePizzaFactory,而不需修改众多的客户。提高了聚合度,PizzaStore的职责是使用pizza对象,SimplePizzaFactory的职责是决定创建什么样的pizza对象。,重写PizzaStore类,public class PizzaStore SimplePizzaFactory factory;public
13、 PizzaStore(SimplePizzaFactory factory)this.factory=factory;public Pizza orderPizza(String type)Pizza pizza;pizza=factory.createPizza(type);pizza.prepare();pizza.bake();pizza.cut();pizza.box();return pizza;/other methods here,简单工厂模式,Pizza可以是一个抽象类,也可以是一个接口。,框架,框架的对外接口,简单工厂模式,有人认为这还不是一个真正的模式,只是一种程序设计的
14、习惯。,授权pizza店,我们的pizza店非常成功,许多人都想开设我们的授权加盟店。但是,不同地区的加盟pizza店可能希望供应不同口味的pizza。怎么解决这个问题呢?,解决方法之一:建立不同的工厂,建立不同的工厂:如NYPizzaFactory、ChicagoPizzaFactory、CaliforniaPizzaFactory,在PizzaStore中包含相应工厂的实例。其代码类似于:/该pizza店提供纽约风味的pizzaNYPizzaFactory nyFactory=new NYPizzaFactory();/建立一个生产纽约风味pizza的工厂PizzaStore nyStor
15、e=new PizzaStore(nyFactory);/建立一个pizza店,引用纽约风味pizza的工厂nyStore.orderPizza(“Veggie”);/生产的是纽约风味的pizza/该pizza店提供芝加哥风味的pizzaChicagoPizzaFactory chicagoFactory=new ChicagoPizzaFactory();PizzaStore chicagoStore=new PizzaStore(chicagoFactory);chicagoStore.orderPizza(“Veggie”);,抽象工厂模式,这么多工厂,可以再增加抽象层让我们一起来设计,
16、另一种解决方法-工厂方法模式,思路:改写的PizzaStore,将createPizza()方法放回到PizzaStore,但是声明为抽象方法,然后,为每一种地方风味创建一个PizzaStore的子类。,改造后的PizzaStore的代码,public abstract class PizzaStore public Pizza orderPizza(String type)Pizza pizza=createPizza(type);pizza.prepare();pizza.bake();pizza.cut();pizza.box();return pizza;abstract Pizza
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- java 工厂 设计 模式 课件

链接地址:https://www.31ppt.com/p-5039968.html