设计模式实验.docx_第1页
设计模式实验.docx_第2页
设计模式实验.docx_第3页
设计模式实验.docx_第4页
设计模式实验.docx_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

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

文档简介

代码重构与设计模式课堂实验徐海蛟博士 2016.03实验一 工厂模式的应用【实验目的】1) 掌握工厂模式(factory)的特点2) 分析具体问题,使用工厂模式进行设计。【实验内容和要求】有一个 oem 制造商代理做 hp 笔记本电脑(laptop),后来该制造商得到了更多的品牌笔记本电脑的订单 acer、lenovo、dell,该 oem 商发现,如果一次同时做很多个牌子的本本,有些不利于管理。利用工厂模式改善设计,用控制台应用程序实现该 oem 制造商的工厂模式。该模式的 uml 图如下。【模式uml图】【模式代码(java 语言实现)】public class factorymethod / 主类 public static void main(string args) computer c; factory f = new dellfactory(); c = f.getcomputertype(); c.computertype(); f = new lenovofactory(); 1代码重构与设计模式课堂实验徐海蛟博士 2016.03 c = f.getcomputertype(); c.computertype(); f = new acerfactory(); c = f.getcomputertype(); c.computertype(); interface factory computer getcomputertype(); class dellfactory implements factory override public computer getcomputertype() return new dell(); class acerfactory implements factory override public computer getcomputertype() return new acer(); class lenovofactory implements factory override public computer getcomputertype() return new lenovo(); /* * 电脑品牌 */ interface computer public void computertype(); class dell implements computer override public void computertype() / todo autogenerated method stub 2代码重构与设计模式课堂实验徐海蛟博士 2016.03 system.out.println(dell computer); class acer implements computer override public void computertype() system.out.println(acer computer); class lenovo implements computer override public void computertype() / todo autogenerated method stub system.out.println(lenovo computer); 【运行截图】【实验小结】通过本次实验,学会了使用工厂方法模式。工厂方法模式的适用性如下:当一个类不知道它所必须创建的对象的类时。当一个类希望由它的子类来指定它所创建的对象时。当类将创建对象的职责委托给多个帮助子类中的某一个,并且希望将哪一个帮助子类是代理这一信息局部化时。3代码重构与设计模式课堂实验徐海蛟博士 2016.03实验二 抽象工厂模式的应用【实验目的】1) 掌握抽象工厂模式(abstract factory)的特点2) 分析具体问题,使用抽象工厂模式进行设计。【实验内容和要求】麦当劳(mcdonalds)和肯德基(kfc)快餐店都经营汉堡(hamburg)和可乐(cola),用 java 控制台应用程序实现这两个快餐店经营产品的抽象工厂模式。该模式的 uml 图如下。【模式 uml 图】【模式代码】 public class abstractfactorytest public static void main(string args) hamburg h; cola c; abstractfactory af = new mdnfactory(); 4代码重构与设计模式课堂实验徐海蛟博士 2016.03 h = af.createhamburg(); c = af.createcola(); h.gethumburg(); c.getcola(); af = new kdjfactory(); h = af.createhamburg(); c = af.createcola(); h.gethumburg(); c.getcola(); interface abstractfactory hamburg createhamburg(); cola createcola(); class mdnfactory implements abstractfactory override public hamburg createhamburg() return new mdnhamburg(); override public cola createcola() return new mdncola(); class kdjfactory implements abstractfactory override public hamburg createhamburg() return new kdjhamburg(); override public cola createcola() return new kdjcola(); /* * kdj & */ interface hamburg 5代码重构与设计模式课堂实验徐海蛟博士 2016.03 void gethumburg(); class mdnhamburg implements hamburg override public void gethumburg() system.out.println(mdnhamburg); class kdjhamburg implements hamburg override public void gethumburg() / todo autogenerated method stub system.out.println(kdjhamburg); interface cola void getcola(); class mdncola implements cola override public void getcola() system.out.println(mdncola); class kdjcola implements cola override public void getcola() system.out.println(kdjcola); 【运行截图】 6代码重构与设计模式课堂实验徐海蛟博士 2016.03【实验小结】抽象工厂模式主要适用于以下情况:一系列要独立于它的产品的创建、组合和表示时。、一个系统要由多个产品系列中的一个来配置时。当要强调一系列相关的产品对象的设计以便进行联合使用时。当要提供一个产品类库,而只要显示它们的接口而不是实现时。7代码重构与设计模式课堂实验徐海蛟博士 2016.03实验三 适配器模式的应用【实验目的】1) 掌握适配器模式(adapter)的特点2) 分析具体问题,使用适配器模式进行设计。【实验内容和要求】一个软件团队开发绘图系统,设计了圆对象(circle)、矩形对象(rectangle),线对象(line)都支持 draw()函数,即可以通过 draw()函数绘制图形。为了加快项目进度,将角度对象(angle)绘制功能交给了合作团队实现。但合作团队将角度对象绘制函数定为了 drawangle()。绘图系统提供给用户后,用户不满意,希望能统一的调用,不用记太多命令。应用适配器模式,用 java 控制台应用程序完善该设计。该模式的 uml 图如下。【模式uml图】【模式代码】public class adaptertest public static void main(string args) paint a = new angleadapter(); a.draw(); 8代码重构与设计模式课堂实验interface paint 徐海蛟博士 2016.03 void draw(); class circle implements paint override public void draw() system.out.println(圆圆); class rectangle implements paint override public void draw() system.out.println(方方); class line implements paint override public void draw() system.out.println(线线); class angle public void drawangle() system.out.println(角度); class angleadapter implements paint private angle a=new angle(); override public void draw() / todo autogenerated method stub a.drawangle(); 【运行截图】9代码重构与设计模式课堂实验徐海蛟博士 2016.03【实验小结】适配器模式主要适用于以下情况:当想要使用一个已经存在的类,但是该类的接口不符合现有的需求时。当需要创建一个可以被复用的类,该类能够与其他无关的类甚至无法预见的类协同工作时。当需要使用一个已经存在的子类,但是不可能对所有的都进行子类化以匹配他们的接口时,对象适配器可以对其父类接口进行适配。10代码重构与设计模式课堂实验徐海蛟博士 2016.03实验四 桥接模式的应用【实验目的】1) 掌握桥接模式(bridge)的特点2) 分析具体问题,使用桥接模式进行设计。【实验内容和要求】一 个 咖 啡 店 可 以 提 供 大 杯 (jorumcoffee) 、 中 杯 (mediumcoffee) 、 小 杯(smallcoffee)的咖啡(coffee),为了满足不同用户的口味,在咖啡中可以添加牛奶(milk),或者糖(sugar),或者柠檬(lemon),提供给用户不同口味的组合,如大杯咖啡加牛奶,中杯咖啡加糖,小杯咖啡加柠檬,小杯咖啡加糖等。应用桥接模式,用 java 控制台应用程序实现该设计。该模式的 uml 图如下。【模式类图】【模式代码】package constructor; public class bridgetest public static void main(string args) bridge b; b=new sugar(); 11代码重构与设计模式课堂实验徐海蛟博士 2016.03 b.setcoffee(new jorumcoffee(); b.getcoffee(); b=new milk(); b.setcoffee(new smallcoffee(); b.getcoffee(); interface coffee void getcoffee(); class jorumcoffee implements coffee override public void getcoffee() / todo autogenerated method stub system.out.print(大杯咖啡); class mediumcoffee implements coffee override public void getcoffee() / todo autogenerated method stub system.out.print(中杯咖啡); class smallcoffee implements coffee override public void getcoffee() / todo autogenerated method stub system.out.print(小杯咖啡); /* * 配料 */ abstract class bridge protected coffee c; void setcoffee(coffee co) c=co; public void getcoffee() c.getcoffee(); 12代码重构与设计模式课堂实验 class sugar extends bridge 徐海蛟博士 2016.03 override public void getcoffee() c.getcoffee(); system.out.println(加糖); class milk extends bridge override public void getcoffee() c.getcoffee(); system.out.println(加牛奶); class lemon extends bridge override public void getcoffee() c.getcoffee(); system.out.println(加柠檬); 【运行截图】【实验小结】桥接模式的适用情况有:当不希望在抽象和它的实现之间有一个固定的绑定关系时。当类的抽象以及它的实现都应该可以通过生成子类的方法加以扩充时。当对一个抽象类的实现部分的修改应对客户不产生影响时。13代码重构与设计模式课堂实验徐海蛟博士 2016.03实验五 装饰模式的应用【实验目的】1) 掌握装饰模式(decorator)的特点2) 分析具体问题,使用装饰模式进行设计。【实验内容和要求】“喜羊羊逃命”游戏:喜羊羊被灰太狼追,喜羊羊最多 5 条命,灰太狼每咬到喜羊羊一次,喜羊羊就要少一条命。在逃的过程中喜羊羊可以吃到三种苹果,吃“红苹果”可以给喜羊羊加上保护罩,吃“绿苹果”可以加快喜羊羊奔跑速度,吃“黄苹果”可以使喜羊羊趟着水跑。应用装饰模式,用 java 控制台应用程序实现该设计。绘制该模式的 uml 图。提示:这个例子如果用类的继承来实现的话那可就麻烦了,你需要为喜羊羊派生 3*2*1=6 个子类(有保护罩的喜羊羊,奔跑速度加快的喜羊羊,会趟水的喜羊羊,既有保护罩又会趟水的喜羊羊,奔跑速度快且会趟水的喜羊羊,有保护罩且奔跑速度快的喜羊羊,有保护罩、奔跑速度快且会趟水的喜羊羊),如果使用装饰模式的那就不用派生诸多子类了,当喜羊羊每吃到一个苹果,我们就用装饰模式给喜羊羊加一个动态增加一个新功能即可。【模式类图】14代码重构与设计模式课堂实验【模式代码】 public class decoratortest01 徐海蛟博士 2016.03 public static void main(string args) concretexiyy cxyy=new concretexiyy(); protectxiyangyang px=new protectxiyangyang(); fastxiyangyang fx=new fastxiyangyang(); swimingxiyangyang sx=new swimingxiyangyang(); px.setxiyangyang(cxyy); px.operation(); fx.setxiyangyang(px); fx.operation(); sx.setxiyangyang(fx); sx.operation(); interface xiyangyang public void operation(); class concretexiyy implements xiyangyang override public void operation() / todo autogenerated method stub system.out.println(喜羊羊); abstract class decorator implements xiyangyang protected xiyangyang xyy; public void setxiyangyang(xiyangyang xyy) this.xyy=xyy; override public void operation() / todo autogenerated method stub xyy.operation(); 15代码重构与设计模式课堂实验徐海蛟博士 2016.03 class protectxiyangyang extends decorator override public void operation() / todo autogenerated method stub system.out.print( 有保护罩的); super.operation(); class fastxiyangyang extends decorator override public void operation() / todo autogenerated method stub system.out.print( 加速的); super.operation(); class swimingxiyangyang extends decorator override public void operation() / todo autogenerated method stub system.out.print( 会游泳的); super.operation(); 【运行截图】【实验小结】装饰模式的适用情况有:当需要以不影响其他对象为前提实现动态、透明地给单个对象添加职责时。当需要将对象的某些职责进行撤销操作时。当不能用生成子类的方法进行当前系统的扩充时。16代码重构与设计模式课堂实验徐海蛟博士 2016.03实验六 代理模式的应用【实验目的】1) 掌握代理模式(proxy)的特点2) 分析具体问题,使用代理模式进行设计。【实验内容和要求】生产商(factory)需要销售商品(product),网上商城(e-shop)提供了一个平台,可以帮助销售这些商品,获得更大的销量。当顾客(custom)从网上商城选购商品的时候,实际是从生产商获得的商品。应用代理模式,用 java 控制台应用程序改进该设计。绘制该模式的 uml 图。【模式uml图】【实验代码】 public class proxytest01 17代码重构与设计模式课堂实验徐海蛟博士 2016.03 public static void main(string args) / todo autogenerated method stub e_shop es=new e_shop(); duct(); abstract class product public abstract void product(); class factory extends product override public void product() / todo autogenerated method stub system.out.println(商品正在促销中,满一百减 50.); class e_shop extends product private factory factory; public e_shop() factory=new factory(); override public void product() / todo autogenerated method stub duct(); 【运行截图】【实验小结】代理模式的有以下几种适用情况:当需要为一个对象在不同的地址空间提供局部的代表时。当需要创建开销非常大的对象时。当需要控制原始对象的访问时。当需要再访问对象时执行一些附加操作时,比如通过代理对象计算访问实际对象的次数。18代码重构与设计模式课堂实验徐海蛟博士 2016.03实验七 观察者模式的应用【实验目的】1) 掌握外观模式(observer)的特点2) 分析具体问题,使用外观模式进行设计。【实验内容和要求】网上商店中如果商品(product)在名称(name)、价格(price)等方面有变化,系统能自动通知会员,将是网上商店区别传统商店的一大特色。如何设计实现? 说明你所选择的设计模式,画出类关系图并指明各个类的角色。应用外观模式,用 java 控制台应用程序改进该设计。绘制该模式的 uml 图。【模式 uml 图】【模式代码】 import java.util.arraylist; public class obeservertest public static void main(string args) / todo autogenerated method stub concretesubject cs=new concretesubject(); cs.attach(new concreteobserver(cs, 1 号会员); cs.attach(new concreteobserver(cs, 2 号会员); cs.attach(new concreteobserver(cs, 3 号会员); cs.attach(new concreteobserver(cs, 4 号会员); cs.setstate(c+编程思想价钱下降 100 元); 19代码重构与设计模式课堂实验徐海蛟博士 2016.03 cs.notify(); abstract class observer public abstract void update(); class concreteobserver extends observer private string name; private string state; private concretesubject cs; public concretesubject getconcretesubject() return cs; public void setconcretesubject(concretesubject cs) this.cs=cs; public concreteobserver(concretesubject cs,string name) this.cs=cs; =name; override public void update() / todo autogenerated method stub state=cs.getstate(); system.out.println(name+观察到的状态是:+state); abstract class subject private arraylist observers=new arraylist(); public void attach(observer o) observers.add(o); public void detach(observer o) observers.remove(o); /通知 public void notify() for (int i = 0; i observers.size(); i+) observers.get(i).update(); 20代码重构与设计模式课堂实验徐海蛟博士 2016.03 class concretesubject extends subject private string state; public void setstate(string state) this.state=state; public string getstate() return state; 【运行截图】【实验小结】观察者模式的适用情况有:当一个抽象模型有两个方面,而其中一个方面必须依赖于另一个方面时。当对一个对象的改变需要同时改变其他对象但是却不知道具体有多少个对象等到改变时。当一个对象必须通知其他对象但是却不能与其他对象造成紧密耦合时。21代码重构与设计模式课堂实验徐海蛟博士 2016.03实验八 职责链模式的应用【实验目的】1) 掌握职责链模式(chain of responsibility)的特点2) 分析具体问题,使用职责链模式进行设计。【实验内容和要求】高校学生请假需要符合学校规定,假如班主任可以批准 1 天假,系主任可以批准 7 天假,各学院院长可以批准 30 天,学校校长可以批准 1 年。应用职责链模式,用 java 控制台应用程序实现该设计。绘制该模式的 uml 图。【模式uml图】【模式代码】 public class studentclient public static void main(string args) / todo autogenerated method stub handler fdy=new fudaoyuan(); handler xzr=new xizhuren(); handler xy=new xueyuan(); handler xx=new xuexiao(); fdy.setsuccessor(xzr); xzr.setsuccessor(xy); xy.setsuccessor(xx); for (int i = 1; i 20; i+=2) fdy.handlerequest(i); 22代码重构与设计模式课堂实验徐海蛟博士 2016.03 /处理请求的接口 abstract class handler protected handler successor; public void setsuccessor(handler successor) this.successor=successor; public abstract void handlerequest(int request); class fudaoyuan extends handler override public void handlerequest(int request) / todo autogenerated method stub if(request=1) system.out.println(this.getclass().getsimplename()+处理了请求+request); else if(this.successor!=null) system.out.println(this.getclass().getsimplename()+自身无法满足请求,转入下一个处理者); this.successor.handlerequest(request); class xizhuren extends handler override public void handlerequest(int request) / todo autogenerated method stub if(request=7) system.out.println(this.getclass().getsimplename()+处理了请求+request); else if(this.successor!=null) system.out.println(this.getclass().getsimplename()+自身无法满足请求,转入下一个处理者); this.successor.handlerequest(request); 23代码重构与设计模式课堂实验 class xueyuan extends handler 徐海蛟博士 2016.03 override public void handlerequest(int request) / todo autogenerated method stub if(request=9) system.out.println(this.getclass().getsimplename()+处理了请求+request); else if(this.successor!=null) system.out.println(this.getclass().getsimplename()+自身无法满足请求,转入下一个处理者); this.successor.handlerequest(request); cla

温馨提示

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

评论

0/150

提交评论