




已阅读5页,还剩304页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
封面,Java设计模式,2019/10/7,1,第一章 设计模式简介,1.1 什么是设计模式,2019/10/7,2,每一个设计模式描述一个在我们周围不断重复发生的问题,以及该问题的解决方案的核心。这样,你就能一次一次地使用该方案而不必做重复劳动。,1.2 设计模式的起源,2019/10/7,3,软件领域的设计模式起源于建筑学。 1977年,建筑大师Alexander出版了A Pattern Language:Towns, Building, Construction一书。受Alexander著作的影响 ,Kent Beck和Ward Cunningham在1987年举行的一次面向对象的会议上发表了论文:在面向对象编程中使用模式。,1.3 GOF之著作,2019/10/7,4,目前,被公认在设计模式领域最具影响力的著作是Erich Gamma、Richard Helm、Ralph Johnson和John Vlissides在1994年合作出版的著作:Design Patterns:Elements of Reusable Object-Oriented Software(中译本设计模式:可复用的面向对象软件的基本原理 或设计模式),该书被广大喜爱者昵称为GOF(Gang of Four)之书,被认为是学习设计模式的必读著作,GOF之书已经被公认为是设计模式领域的奠基之作。,1.4 学习设计模式的重要性,2019/10/7,5,学习设计模式不仅可以使我们使用好这些成功的模式,更重要的是可以使我们更加深刻地理解面向对象的设计思想,非常有利于我们更好地使用面向对象语言解决设计中的问题。,1.5 合理使用模式,2019/10/7,6,1正确使用 2避免教条 3模式挖掘,第二章 面向对象的几个基本原则,2.1 面向抽象原则,2019/10/7,7,设计一个类时,不让该类面向具体的类,而是面向抽象类或接口 。,第二章 面向对象的几个基本原则,2019/10/7,8,public class Circle double r;Circle(double r)this.r=r; public double getArea() return 3.14*r*r;,public class Pillar Circle bottom; double height; Pillar(Circle bottom,double height) this.bottom=bottom;this.height=height;,定义底面为三角形的柱体?,第二章 面向对象的几个基本原则,2019/10/7,9,public abstract class Geometry public abstract double getArea(); ,public class Pillar Geometry bottom; double height; Pillar(Circle bottom,double height) this.bottom=bottom;this.height=height;,2.2 开-闭原则,2019/10/7,10,设计应当对扩展开放,对修改关闭。 如果您的设计遵守了“开-闭原则”,那么这个设计一定是易维护的,因为在设计中增加新的模块时,不必去修改设计中的核心模块。,2.3 高内聚-低耦合原则,2019/10/7,11,如果类中的方法是一组相关的行为,则称该类是高内聚的,反之称为低内聚的。 所谓低耦合就是尽量不要让一个类含有太多的其它类的实例的引用,以避免修改系统的其中一部分会影响到其它部分。,第四章 命令模式,2019/10/7,12,命令模式(别名:动作,事务) 将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化;对请求排队或记录请求日志,以及支持可撤消的操作。 Command Pattern(Another Name: Action, Transaction) Encapsulate a request as an object, thereby letting you parameterize clients with different requests, queue or log requests, and support undoable operations.,一 、 概述,2019/10/7,13,在许多设计中,经常涉及到一个对象请求另一个对象调用其方法到达某种目的。如果请求者不希望或无法直接和被请求者打交道,即不希望或无法含有被请求者的引用,那么就可以使用命令模式。,实例,在军队作战中,指挥官请求三连偷袭敌人,但是指挥官不希望或无法直接与三连取得联系,那么可以将该请求:“三连偷袭敌人”形成一个“作战命令”。只要能让该作战命令被执行,就会实现三连偷袭敌人的目的。,二、命令模式的结构与使用,2019/10/7,15,模式的结构中包括四种角色: 接收者(Receiver) 命令(Command)接口 具体命令(ConcreteCommand) 请求者(Invoker),2019/10/7,16,模式的UML类图,2019/10/7,17,模式的结构的描述与使用,1接收者(Receiver) : CompanyArmy.java public class CompanyArmy public void sneakAttack() System.out.println(“我们知道如何偷袭敌人,保证完成任务“); ,2019/10/7,18,模式的结构的描述与使用,2命令(Command)接口 : Command.java public interface Command public abstract void execute(); ,2019/10/7,19,模式的结构的描述与使用,3具体命令(ConcreteCommand) ConcreteCommand.java public class ConcreteCommand implements Command CompanyArmy army; /含有接收者的引用 ConcreteCommand(CompanyArmy army) this.army=army; public void execute() /封装着指挥官的请求 army.sneakAttack(); /偷袭敌人 ,2019/10/7,20,模式的结构的描述与使用,4请求者(Invoker) ArmySuperior.java public class ArmySuperior Command command; /用来存放具体命令的引用 public void setCommand(Command command) mand=command; public void startExecuteCommand() /让具体命令执行execute()方法 command.execute(); ,2019/10/7,21,模式的结构的描述与使用,5应用 Application.java public class Application public static void main(String args) CompanyArmy 三连=new CompanyArmy(); Command command=new ConcreteCommand(三连); ArmySuperior 指挥官=new ArmySuperior(); 指挥官.setCommand(command); 指挥官.startExecuteCommand(); ,三、命令模式的优点,2019/10/7,22,在命令模式中,请求者(Invoker)不直接与接收者(Receiver)交互,即请求者(Invoker)不包含接收者(Receiver)的引用,因此彻底消除了彼此之间的耦合。 命令模式满足“开-闭原则”。如果增加新的具体命令和该命令的接受者,不必修改调用者的代码,调用者就可以使用新的命令对象;反之,如果增加新的调用者,不必修改现有的具体命令和接受者,新增加的调用者就可以使用已有的具体命令。,四、应用举例,模拟带控制开关的小电器。该电器上有四个开关,两个一组,其中一组负责打开、关闭小电器上的照明灯,另一组负责打开、关闭小电器上的摄像头。,第五章 观察者模式,2019/10/7,24,观察者模式(别名:依赖,发布-订阅) 定义对象间的一种一对多的依赖关系,当一个对象的状态发生变化时,所有依赖于它的对象都得到通知并被自动更新。 Observer Pattern(Another Name: Dependents, Publish-Subscribe) Define a one-to-many dependency between objects so that when one object changes state, all its dependents are notified and updated automatically,一 、 概述,2019/10/7,25,在许多设计中,经常涉及到多个对象都对一个特殊对象中的数据变化感兴趣,而且这多个对象都希望跟踪那个特殊对象中的数据变化。,实例,某些寻找工作的人对“求职中心”的职业需求信息的变化非常关心,很想跟踪“求职中心”中职业需求信息的变化。“求职者”可以让“求职中心”把自己登记下来,这样求职中心就会及时通知她最新的职业信息需求。,二、 模式的结构与使用,2019/10/7,27,观察者模式的结构中包括四种角色: 主题(Subject) 观察者(Observer) 具体主题(ConcreteSubject) 具体观察者(ConcreteObserver),2019/10/7,28,模式的UML类图,2019/10/7,29,模式的结构的描述与使用,1主题 : Subject.java public interface Subject public void addObserver(Observer o); public void deleteObserver(Observer o); public void notifyObservers(); ,2019/10/7,30,模式的结构的描述与使用,2观察者 : Obsever.java public interface Observer public void hearTelephone(String heardMess); ,2019/10/7,31,模式的结构的描述与使用,3具体主题 SeekJobCenter.java_1 import java.util.ArrayList; public class SeekJobCenter implements Subject String mess; boolean changed; ArrayList personList; SeekJobCenter() personList=new ArrayList(); mess=“; changed=false; public void addObserver(Observer o) if(!(personList.contains(o) personList.add(o); public void deleteObserver(Observer o) if(personList.contains(o) personList.remove(o); ,2019/10/7,32,模式的结构的描述与使用,3具体主题 SeekJobCenter.java_2 public void notifyObservers() if(changed)for(int i=0;ipersonList.size();i+) Observer observer=personList.get(i); observer.hearTelephone(mess); changed=false; public void giveNewMess(String str) if(str.equals(mess) changed=false; else mess=str; changed=true; ,2019/10/7,33,模式的结构的描述与使用,4具体观察者_1 UniversityStudent.java import java.io.*; public class UniverStudent implements Observer Subject subject; File myFile; UniverStudent(Subject subject,String fileName) this.subject=subject; subject.addObserver(this); /使当前实例成为subject所引用的具体主题的观察者 myFile=new File(fileName); public void hearTelephone(String heardMess) try RandomAccessFile out=new RandomAccessFile(myFile,“rw“); out.seek(out.length(); byte b=heardMess.getBytes(); out.write(b); /更新文件中的内容 System.out.print(“我是一个大学生,“); System.out.println(“我向文件“+myFile.getName()+“写入如下内容:“); System.out.println(heardMess); catch(IOException exp) System.out.println(exp.toString(); ,2019/10/7,34,模式的结构的描述与使用,4具体观察者_2 HaiGui.java import java.io.*; import java.util.regex.*; public class HaiGui implements Observer Subject subject; File myFile; HaiGui(Subject subject,String fileName) this.subject=subject; subject.addObserver(this); /使当前实例成为subject所引用的具体主题的观察者 myFile=new File(fileName); public void hearTelephone(String heardMess) try boolean boo=heardMess.contains(“java程序员“)|heardMess.contains(“软件“); if(boo) RandomAccessFile out=new RandomAccessFile(myFile,“rw“); out.seek(out.length(); byte b=heardMess.getBytes(); out.write(b); System.out.print(“我是一个海归,“); System.out.println(“我向文件“+myFile.getName()+“写入如下内容:“); System.out.println(heardMess); else System.out.println(“我是海归,这次的信息中没有我需要的信息“); catch(IOException exp) System.out.println(exp.toString(); ,2019/10/7,35,模式的结构的描述与使用,5应用 Application.java public class Application public static void main(String args) SeekJobCenter center=new SeekJobCenter(); UniverStudent zhangLin=new UniverStudent(center,“A.txt“); HaiGui wangHao=new HaiGui(center,“B.txt“); center.giveNewMess(“腾辉公司需要10个java程序员。“); center.notifyObservers(); center.giveNewMess(“海景公司需要8个动画设计师。“); center.notifyObservers(); center.giveNewMess(“仁海公司需要9个电工。“); center.notifyObservers(); center.giveNewMess(“仁海公司需要9个电工。“); center.notifyObservers(); ,三、观察者模式的优点,2019/10/7,36,具体主题和具体观察者是松耦合关系。由于主题(Subject)接口仅仅依赖于观察者(Observer)接口,因此具体主题只是知道它的观察者是实现观察者(Observer)接口的某个类的实例,但不需要知道具体是哪个类。同样,由于观察者仅仅依赖于主题(Subject)接口,因此具体观察者只是知道它依赖的主题是实现主题(subject)接口的某个类的实例,但不需要知道具体是哪个类。 观察模式满足“开-闭原则”。主题(Subject)接口仅仅依赖于观察者(Observer)接口,这样,我们就可以让创建具体主题的类也仅仅是依赖于观察者(Observer)接口,因此如果增加新的实现观察者(Observer)接口的类,不必修改创建具体主题的类的代码。同样,创建具体观察者的类仅仅依赖于主题(Observer)接口,如果增加新的实现主题(Subject)接口的类,也不必修改创建具体观察者类的代码。,四、应用举例,指挥部希望按时得到水文站测量到的关于水流的信息,比如流量、流速等。,第六章 装饰模式,2019/10/7,38,装饰模式(别名:包装器) 动态地给对象添加一些额外的职责。就功能来说装饰模式相比生成子类更为灵活。 Decorator Pattern(Another Name: Wrapper) Attach additional responsibilities to an object dynamically. Decorators provide a flexible alternative to subclassing for extending functionality.,一 、 概述,2019/10/7,39,装饰模式是动态地扩展一个对象的功能,而不需要改变原始类代码的一种成熟模式。在装饰模式中,“具体组件”类和“具体装饰”类是该模式中的最重要的两个角色。,实例,2019/10/7,40,假设系统中有一个Bird抽象类以及Bird类的一个子类:Sparrow。 Sparrow类实现了Bird类的fly方法,使得Sparrow类创建的对象 调用fly方法能连续飞行100米。现在用户需要两种鸟,必须分别 能连续飞行150米和200米。,二、装饰模式模式的结构与使用,2019/10/7,41,装饰模式的结构中包括四种角色: 抽象组件(Component) 具体组件(ConcreteComponent) 装饰(Decorator) 具体装饰(ConcreteDecotator),2019/10/7,42,装饰模式的UML类图,2019/10/7,43,装饰模式的结构的描述与使用,1抽象组件 : Bird.java public abstract class Bird public abstract int fly(); ,2019/10/7,44,装饰模式的结构的描述与使用,2具体组件 : Sparrow.java public class Sparrow extends Bird public final int DISTANCE=100; public int fly() return DISTANCE; ,2019/10/7,45,装饰模式的结构的描述与使用,3装饰 (Decorator): Decorator.java public abstract class Decorator extends Bird protected Bird bird; public Decorator() public Decorator(Bird bird) this.bird=bird; ,2019/10/7,46,装饰模式的结构的描述与使用,4具体装饰(ConcreteDecotator): SparrowDecorator.java public class SparrowDecorator extends Decorator public final int DISTANCE=50; /eleFly方法能飞50米 SparrowDecorator(Bird bird) super(bird); public int fly() int distance=0; distance=bird.fly()+eleFly(); return distance; private int eleFly() /装饰者新添加的方法 return DISTANCE; ,2019/10/7,47,装饰模式的结构的描述与使用,5应用 Application.java public class Application public void needBird(Bird bird) int flyDistance=bird.fly(); System.out.println(“这只鸟能飞行“+flyDistance +“米“); public static void main(String args) Application client=new Application (); Bird sparrow=new Sparrow(); Bird sparrowDecorator1= new SparrowDecorator(sparrow); Bird sparrowDecorator2= new SparrowDecorator(sparrowDecorator1); client.needBird(sparrowDecorator1); client.needBird(sparrowDecorator2); ,三、装饰模式的优点,2019/10/7,48,被装饰者和装饰者是松耦合关系。由于装饰(Decorator)仅仅依赖于抽象组件(Component),因此具体装饰只知道它要装饰的对象是抽象组件的某一个子类的实例,但不需要知道是哪一个具体子类。 装饰模式满足“开-闭原则”。不必修改具体组件,就可以增加新的针对该具体组件的具体装饰。 可以使用多个具体装饰来装饰具体组件的实例。,四、应用举例,当前系统已有一个抽象类ReadWord,该类有一个抽象方法readWord(),另外还有一个ReadWord类的子类ReadEnglishWord,该类的readWord()方法可以读取一个由英文单词构成的文本文件word.txt。系统已有类的类图如图6.11所示。目前已有一些客户在使用该系统,并使用ReadWord类的对象调用readWord()方法读取文件中的单词。,四、应用举例,现有部分用户希望使用ReadWord类的对象调用readWord()方法读取文件word.txt中的单词,并希望同时也能得到该单词 的汉语解释,也有一些用户希望不仅能得到该单词汉语解释也能得到该单词的英文例句。要求不允许修改现有系统的代码以及word.txt文件,对系统进行扩展以满足用户需求。,第七章 策略模式,2019/10/7,51,策略模式(别名:政策) 定义一系列算法,把它们一个个封装起来,并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。 Strategy Pattern(Another Name: Policy) Define a family of algorithms, encapsulate each one, and make them inter changeable. Strategy lets the algorithm vary independently from clients that use it.,一 、 概述,2019/10/7,52,策略模式是处理算法的不同变体的一种成熟模式,策略模式通过接口或抽象类封装算法的标识,即在接口中定义一个抽象方法,实现该接口的类将实现接口中的抽象方法。 在策略模式中,封装算法标识的接口称作策略,实现该接口的类称作具体策略。,实例,2019/10/7,53,策略模式是处理算法的不同变体的一种成熟模式,策略模式通过接口或抽象类封装算法的标识,即在接口中定义一个抽象方法,实现该接口的类将实现接口中的抽象方法。 在策略模式中,封装算法标识的接口称作策略,实现该接口的类称作具体策略。,二、策略模式的结构与使用,2019/10/7,54,策略模式的结构中包括三种角色: 策略(Strategy) 具体策略(ConcreteStrategy) 上下文(Context),2019/10/7,55,策略模式的UML类图,2019/10/7,56,策略模式的结构的描述与使用,1策略(Strategy) : Computable.java public interface ComputableStrategy public abstract double computeScore(double a); ,2019/10/7,57,策略模式的结构的描述与使用,2具体策略(ConcreteStrategy): StrategyOne.java public class StrategyOne implements ComputableStrategy public double computeScore(double a) double score=0,sum=0; for(int i=0;ia.length;i+) sum=sum+ai; score=sum/a.length; return score; ,2019/10/7,58,策略模式的结构的描述与使用,2具体策略(ConcreteStrategy): StrategyTwo.java public class StrategyTwo implements ComputableStrategy public double computeScore(double a) double score=0,multi=1; int n=a.length; for(int i=0;ia.length;i+) multi=multi*ai; score=Math.pow(multi,1.0/n); return score; ,2019/10/7,59,策略模式的结构的描述与使用,2具体策略(ConcreteStrategy): StrategyThree.java import java.util.Arrays; public class StrategyThree implements ComputableStrategy public double computeScore(double a) if(a.length=2) return 0; double score=0,sum=0; Arrays.sort(a); for(int i=1;ia.length-1;i+) sum=sum+ai; score=sum/(a.length-2); return score; ,2019/10/7,60,策略模式的结构的描述与使用,3上下文: GymnasticsGame.java public class GymnasticsGame ComputableStrategy strategy; public void setStrategy(ComputableStrategy strategy) this.strategy=strategy; public double getPersonScore(double a) if(strategy!=null) return puteScore(a); else return 0; ,2019/10/7,61,策略模式的结构的描述与使用,4应用: Application.java_1 public class Application public static void main(String args) GymnasticsGame game=new GymnasticsGame(); game.setStrategy(new StrategyOne(); Person zhang=new Person(); zhang.setName(“张三“); double a=9.12,9.25,8.87,9.99,6.99,7.88; Person li=new Person(); li.setName(“李四“); double b=9.15,9.26,8.97,9.89,6.97,7.89; zhang.setScore(game.getPersonScore(a); li.setScore(game.getPersonScore(b); System.out.println(“使用算术平均值方案:“); System.out.printf(“%s最后得分:%5.3f%n“,zhang.getName(),zhang.getScore(); System.out.printf(“%s最后得分:%5.3f%n“,li.getName(),li.getScore(); game.setStrategy(new StrategyTwo(); zhang.setScore(game.getPersonScore(a); li.setScore(game.getPersonScore(b); System.out.println(“使用几何平均值方案:“); System.out.printf(“%s最后得分:%5.3f%n“,zhang.getName(),zhang.getScore(); System.out.printf(“%s最后得分:%5.3f%n“,li.getName(),li.getScore();,2019/10/7,62,策略模式的结构的描述与使用,4应用: Application.java_2 game.setStrategy(new StrategyThree(); zhang.setScore(game.getPersonScore(a); li.setScore(game.getPersonScore(b); System.out.println(“使用(去掉最高、最底)算术平均值方案:“); System.out.printf(“%s最后得分:%5.3f%n“,zhang.getName(),zhang.getScore(); System.out.printf(“%s最后得分:%5.3f%n“,li.getName(),li.getScore(); class Person String name; double score; public void setScore(double t) score=t; public void setName(String s) name=s; public double getScore() return score; public String getName() return name; ,三、策略模式的优点,2019/10/7,63,上下文(Context)和具体策略(ConcreteStrategy)是松耦合关系。因此上下文只知道它要使用某一个实现Strategy接口类的实例,但不需要知道具体是哪一个类。 策略模式满足“开-闭原则”。当增加新的具体策略时,不需要修改上下文类的代码,上下文就可以引用新的具体策略的实例。,第八章 适配器模式,2019/10/7,64,适配器模式(别名:包装器) 将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。 Adapter Pattern(Another Name: Wrapper) Convert the interface of a class into another interface clients expect. Adapter lets classes work together that couldnt otherwise because of incompatible interfaces.,一 、 概述,2019/10/7,65,适配器模式是将一个类的接口(被适配者)转换成客户希望的另外一个接口(目标)的成熟模式,该模式中涉及有目标、被适配者和适配器。适配器模式的关键是建立一个适配器,这个适配器实现了目标接口并包含有被适配者的引用。,实例,2019/10/7,66,用户已有一个两相的插座,但最近用户又有了一个新的三相插座。用户现在已经有一台洗衣机和一台电视机,洗衣机按着三相插座的标准配有三相插头,而电视机按着两相插座的标准配有两相插头。现在用户想用新的三相插座来使用洗衣机和电视机。,二、适配器模式的结构与使用,2019/10/7,67,模式的结构中包括三种角色: 目标(Target) 被适配者(Adaptee) 适配器(Adapter),2019/10/7,68,模式的UML类图,2019/10/7,69,模式的结构的描述与使用,1目标(Target) : ThreeElectricOutlet.java public interface ThreeElectricOutlet public abstract void connectElectricCurrent(); ,2019/10/7,70,模式的结构的描述与使用,2被适配者(Adaptee): TwoElectricOutlet.java public interface TwoElectricOutlet public abstract void connectElectricCurrent(); ,2019/10/7,71,模式的结构的描述与使用,3适配器(Adapter) TreeElectricAdapter.java public class TreeElectricAdapter implements ThreeElectricOutlet TwoElectricOutlet outlet; TreeElectricAdapter(TwoElectricOutlet outlet) this.outlet=outlet; public void connectElectricCurrent() outlet.connectElectricCurrent(); ,2019/10/7,72,模式的结构的描述与使用,4应用 Application.java_1 public class Application public static void main(String args) ThreeElectricOutlet outlet; Wash wash=new Wash(); outlet=wash; System.out.println(“使用三相插座接通电流:“); outlet.connectElectricCurrent(); TV tv=new TV(); TreeElectricAdapter adapter=new TreeElectricAdapter(tv); outlet=adapter; System.out.println(“使用三相插座接通电流:“); outlet.connectElectricCurrent(); ,2019/10/7,73,模式的结构的描述与使用,4应用 Application.java_2 class Wash implements ThreeElectricOutlet String name; Wash() name=“黄河洗衣机“; Wash(String s) name=s; public void connectElectricCurrent() turnOn(); public void turnOn() System.out.println(name+“开始洗衣物。“); ,2019/10/7,74,模式的结构的描述与使用,4应用 Application.java_3 class TV implements TwoElectricOutlet String name; TV() name=“长江电视机“; TV(String s) name=s; public void connectElectricCurrent() turnOn(); public void turnOn() System.out.println(name+“开始播放节目。“); ,三、适配器模式的优点,2019/10/7,75,目标(Target)和被适配者(Adaptee)是完全解耦的关系。 适配器模式满足“开-闭原则”。当添加一个实现Adaptee接口的新类时,不必修改Adapter,Adapter就能对这个新类的实例进行适配。,第九章 责任链模式,2019/10/7,76,责任链模式 使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。 Chain of Responsibility Pattern Avoid coupling the sender of a request to its receiver by giving more than one object a chance to handle the request. Chain the receiving objects and pass the request along the chain until an object handles it.,一 、 概述,2019/10/7,77,责任链模式是使用多个对象处理用户请求的成熟模式,责任链模式的关键是将用户的请求分派给许多对象,这些对象被组织成一个责任链,即每个对象含有后继对象的引用,并要求责任链上的每个对象,如果能处理用户的请求,就做出处理,不再将用户的请求传递给责任链上的下一个对象;如果不能处理用户的请求,就必须将用户的请求传递给责任链上的下一个对象。,一 、 实例,2019/10/7,78,用户提交一个人的身份证号码,想知道该人是在北京、上海或者天津居住。,二、责任链模式的结构与使用,2019/10/7,79,模式的结构中包括两种角色: 处理者(Handler) 具体处理者(ConcreteHandler),2019/10/7,80,模式的UML类图,2019/10/7,81,模式的结构的描述与使用,1处理者(Handler): Handler.java public interface Handler public abstract void handleRequest(String number); public abstract void setNextHandler(Handler handler); ,2019/10/7,82,模式的结构的描述与使用,2具体处理者(ConcreteHandler)_1: Beijing.java import java.util.*; public class Beijing implements Handler private Handler handler; private ArrayList numberList; Beijing() numberList=new ArrayList(); numberList.add(“11129812340930034“); numberList.add(“10120810340930632“); numberList.add(“22029812340930034“); numberList.add(“32620810340930632“); public void handleRequest(String number) if(numberList.contains(number) System.out.println(“该人在北京居住“); else System.out.println(“该人不在北京居住“); if(handler!=null) handler.handleRequest(number); public void setNextHandler(Handler handler) this.handler=handler; ,2019/10/7,83,模式的结构的描述与使用,2具体处理者(ConcreteHandler)_2: Shanghai.java import java.util.*; public class Shangh
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 行政法学实践中的应用与试题及答案
- 历史人物对现代管理的启发试题及答案
- 行政管理专业文化概论试题及答案
- 护理职业发展策略试题及答案
- 突破行政法学考试的困境试题及答案
- 2025年药师药品使用技巧试题及答案
- 2025年执业药师案例分析试题及答案
- 2025年药师考试常见药物知识试题及答案
- 2025年语文考试复习手册试题及答案
- 2025年卫生资格考试快速复习技巧试题及答案
- 初二地理考试试题及答案
- 2024第41届全国中学生物理竞赛预赛试题(含答案)
- 2024年阿坝州黑水县招聘社区工作者考试真题
- 内镜洗消相关试题及答案
- 2024年中国铁路国际有限公司招聘真题
- 石油化工阀门检修及维护措施
- 2024年广西物流职业技术学院招聘教职人员笔试真题
- 2024-2025湘科版小学科学四年级下册期末考试卷及答案(三套)
- 大型海上发电用双燃料燃气轮机企业数字化转型与智慧升级战略研究报告
- 工程承包再转让合同协议
- (广东二模)2025年广东省高三高考模拟测试(二)历史试卷(含答案)
评论
0/150
提交评论