架构分析与设计模式_第1页
架构分析与设计模式_第2页
架构分析与设计模式_第3页
架构分析与设计模式_第4页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、架构分析与设计模式摘要:一个设计模式是针对某一类问题的最佳解决方案,而且已经成功应用于许多系统的设计中,它解决了在某种特定情境中重复发生的某个问题,因此设计模式可以被定义为:设计模式是从许多优秀的软件系统中总结出成功的可复用的设计方案。1. 关键字:工厂方法模式、 简单的程序实现、架构分析、设计模式工厂方法模式2. 工厂方法模式的介绍工厂方法 (Factory Method) 模式的意义是定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类当中。核心工厂类不再负责产品的创建,这样核心类成为一个抽象工厂角色,仅负责具体工厂子类必须实现的接口,这样进一步抽象化的好处是使得工厂方法模式可以使系统

2、在不修改具体工厂角色的情况下引进新的产品。1.1 工厂方法模式角色与结构抽象工厂 (Creator) 角色:是工厂方法模式的核心, 与应用程序无关。 任何在模式中创建的对象的工厂类必须实现这个接口。具体工厂 (Concrete Creator) 角色:这是实现抽象工厂接口的具体工厂类,包含与应用程序密切相关的逻辑,并且受到应用程序调用以创建产品对象。抽象产品 (Product)角色:工厂方法模式所创建的对象的超类型,也就是产品对象的共同父类或共同拥有的接口。在上图中,这个角色是Light 。具体产品 (Concrete Product) 角色:这个角色实现了抽象产品角色所定义的接口。某具体产品

3、有专门的具体工厂创建,它们之间往往一一对应。1.2 工厂方法模式的应用工厂方法经常用在以下两种情况中:第一种情况是对于某个产品,调用者清楚地知道应该使用哪个具体工厂服务,实例化该具体工厂, 生产出具体的产品来。 Java Collection中的 iterator()法即属于这种情况。方第二种情况,只是需要一种产品,而不想知道也不需要知道究竟是哪个工厂为生产的,即最终选用哪个具体工厂的决定权在生产者一方,它们根据当前系统的情况来实例化一个具体的工厂返回给使用者,而这个决策过程这对于使用者来说是透明的。1.3 工厂方法模式的适用环境在以下情况下可以使用工厂方法模式:( 1)一个类不知道它所需要的

4、对象的类:在工厂方法模式中,客户端不需要知道具体产品类的类名,只需要知道所对应的工厂即可,具体的产品对象由具体工厂类创建;客户端需要知道创建具体产品的工厂类。( 2)一个类通过其子类来指定创建哪个对象:在工厂方法模式中,对于抽象工厂类只需要提供一个创建产品的接口,而由其子类来确定具体要创建的对象,利用面向对象的多态性和里氏代换原则,在程序运行时,子类对象将覆盖父类对象,从而使得系统更容易扩展。( 3)将创建对象的任务委托给多个工厂子类中的某一个,客户端在使用时可以无需关心是哪一个工厂子类创建产品子类,需要时再动态指定,可将具体工厂类的类名存储在配置文件或数据库中。2 简单的程序实现下面是一个简

5、单的水果生产程序,描述农场种植水果的过程,目的是通过此次设计更进一步了解工程设计模式,加强编程的结构化能力。2.1 程序设计程序设计如下:在这个系统里需要描述下列的水果:葡萄 Grape草莓 Strawberry苹果 Apple水果生产的过程就是生长,成熟后采摘。那么一个自然的作法就是建立一个各种水果都适用的接口,以便与农场里的其他植物区分开。水果接口规定出所有的水果必须实现的接口,包括任何水果类必须具备的方法:种植 plant() ,生长 grow() 以及收获 harvest() 。代码清单 1:接口 Fruit的源代码public interface Fruit / 生长void gro

6、w();/ 收获void harvest();/ 种植void plant();Apple 类是水果类的一种,因此它实现了水果接口所声明的所有方法。另外,由于苹果是多年生植物,因此多出一个treeAge性质,描述苹果树的树龄。下面是这个苹果类的源代码。代码清单 2:类 Apple 的源代码public class Appleimplements Fruit private int treeAge;/ 生长public void grow() log("Apple is growing.");/ 收获public void harvest() log("Apple

7、has been harvested.");/ 种植public void plant() log("Apple has been planted.");/private boolean seedless;/ 生长public void grow() log("Grape is growing.");/ 收获public void harvest() log("Grape has been harvested.");/ 种植public void plant() log("Grape has been plante

8、d.");/ 辅助方法public static void log(String msg) / 有无籽的取值方法public boolean getSeedless() return seedless;/ 有无籽的赋值方法public void setSeedless(boolean seedless) this.seedless = seedless;Strawberry类实现了 Fruit接口,因此,也是水果类型的子类型,其源代码如下所示。代码清单 4:类 Strawberry的源代码public class Strawberryimplements Fruit / 生长publ

9、ic void grow() log("Strawberry is growing.");/ 收获public void harvest() log("Strawberry has been harvested.");/种植public void plant() log("Strawberry has been planted.");/辅助方法public static void log(String msg) 农场的园丁也是系统的一部分,自然要由一个合适的类来代表。这个类就FruitGardener类,其结构由下面描述。FruitG

10、ardener类会根据客户端的要求,创建出不同的水果对象,比如苹果(Apple),葡萄(Grape)或草莓(Strawberry)的实例。而如果接到不合法的要求,FruitGardener类会抛出BadFruitException异常。园丁类的源代码如下所示。代码清单5:FruitGardener类的源代码public class FruitGardener /静态工厂方法public static Fruit factory(String which) throws BadFruitException if (which.equalsIgnoreCase("apple")

11、 return new Apple();else if (which.equalsIgnoreCase("strawberry") return new Strawberry();else if (which.equalsIgnoreCase("grape") return new Grape();else throw new BadFruitException("Bad fruit request");可以看出,园丁类提供了一个静态工厂方法。在客户端的调用下,这个方法创建客户端所需要的水果对象。如果客户端的请求是系统所不支持的,工厂

12、方法就会抛出一个BadFruitException异常。这个异常类的源代码如下所示。辅助方法public static void log(String msg) /树龄的取值方法public int getTreeAge() return treeAge;/树龄的赋值方法public void setTreeAge(int treeAge) this.treeAge = treeAge;代码清单6:BadFruitException类的源代码public class BadFruitExceptionextends Exception public BadFruitException(Stri

13、ng msg) super(msg);在使用时,客户端只需调用FruitGardener的静态方法factory()即可。请见下面的示意性客户端源代码。代码清单7:实现种植即Main()的实现public class PlantFruit public PlantFruit() public static void main(String args) PlantFruit plantfruit = new PlantFruit();try /种植葡萄FruitGardener.factory("grape").plant();FruitGardener.factory(&q

14、uot;grape").grow();FruitGardener.factory("grape").harvest();/种植苹果FruitGardener.factory("apple").plant();FruitGardener.factory("apple").grow();FruitGardener.factory("apple").harvest();/种植草莓FruitGardener.factory("strawberry").plant();FruitGardener

15、.factory("strawberry").grow();FruitGardener.factory("strawberry").harvest();catch (BadFruitException e) 到此为止,我们的简单程序已经设计完成,我们可以通过创建FruitGardener对象来完成水果的种植,无论你要种什么,只需调用对象中的factory()方法。工厂类的示意性源代码如下所示。可以看出,这个工厂方法创建了一个新的具体产品的实例并返还给调用者。代码清单 8: Creator类的源代码public class Creator/静态工厂方法public static Product factory()return new ConcreteProduct();抽象产品角色的主要目的是给所有的具体产品类提供一个共同的类型,在最简单的情况下,可以简化为一个标识接口。所谓标识接口,就是没有声明任何方法的空接口。代码清单 9:抽象角色Product接口的源代码public interface Product具体

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论