ImageVerifierCode 换一换
格式:DOC , 页数:69 ,大小:447.50KB ,
资源ID:7025177      下载积分:10 金币
快捷注册下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/7025177.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请

   平台协调中心        【在线客服】        免费申请共赢上传

权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:0574-28810668;投诉电话:18658249818。

注意事项

本文(Java的23种设计模式(疯狂Java总结).doc)为本站上传会员【xrp****65】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

Java的23种设计模式(疯狂Java总结).doc

1、 Java设计模式(疯狂Java联盟版) 创建型模式 1.抽象工厂模式 AbstractFactory 2.建造者模式 Builder 3.工厂方法模式 Factory Method 4.原型模式 Prototype 5.单例模式 Singleton 结构型模式 1.适配器模式 Adapter 2.桥接模式 Bridge 3.组合模式 Composite 4.装饰模式 Decorator 5.外观模式 Facade 6.享元模式 Flyweight 7.代理模式 Proxy 行为模式 1.职责链模式 Ch

2、ain of Responsibility 2.命令模式 Command 3.解释器模式 Interpreter 4.迭代器模式 Iterator 5.中介者模式 Mediator 6.备忘录模式 Memento 7.观察者模式 Observer 8.状态模式 State 9.策略模式 Strategy 10.模板方法模式 Template Method 11.访问者模式 Visitor Java设计模式(疯狂Java联盟版) 目录 1. 设计模式 3 1.1 创建型模式 4 1.1.1 工厂方法 4 1.1.2 抽象工厂 6

3、 1.1.3 建造者模式 10 1.1.4 单态模式 13 1.1.5 原型模式 15 1.2 结构型模式 17 1.2.1 适配器模式 17 1.2.2 桥接模式 19 1.2.3 组合模式 23 1.2.4 装饰模式 26 1.2.5 外观模式 29 1.2.6 享元模式 32 1.2.7 代理模式 34 1.3 行为型模式 37 1.3.1 责任链模式 37 1.3.2 命令模式 40 1.3.3 解释器模式 43 1.3.4 迭代器模式 45 1.3.5 中介者模式 49 1.3.6 备忘录模式 52 1.3.7 观察者模式 54 1.3.8 状态

4、模式 58 1.3.9 策略模式 61 1.3.10 模板方法 63 1.3.11 访问者模式 65 68 1. 设计模式(超级详细) 内容简介 有感于设计模式在日常开发中的重要性,同时笔者也自觉对设计模式小有心得,故笔者*写二十三种设计模式的简单例子、 并整理二十三种设计模式的理论部分,综合汇总成这份Java设计模式(疯狂J*va联盟版),希望对大家有所帮助。 本份帮助文档主要是为了向读者介绍二十三种设计模式,包括模式的描述,适用性,模*的组成部分,并附带有简单的例 子和类*,目的是为了让读*了解二十三种*计模式,并能方便的查阅各种设计模

5、的用法及注意点。 所附的例子非常简单,慢慢的引导读者从浅到深了解设计模式,并能从中享受设计的乐趣。 由于每个人对设计*式的理解都不尽一致,因此,可能本文档的例子*有不恰当的地方,还望各位读者指出不恰当的地方。 欢迎登录疯狂J*va联盟进行技术交流,疯狂Java联盟的论坛宗旨是: 所有的技术发帖,均有回复。 疯狂Java联盟网址:http://www.crazyit.org 笔者简介 笔者曾师从李刚老师学习Java,现居广州。对Java软件开发、各种Java开源技术都非常感兴趣,曾参与开发、主持*发过大 量Java、J

6、ava EE项目,对Java、Java *E项目有一定认识*见解。欢迎大家与笔者就Java、Java EE相*方面进行技术交流。 笔者现为疯狂Jav*联盟的总版主(论坛ID:杨恩雄),也希望通过该平台与大家分享Java、Java EE技术、*得。 本人邮箱:yangenxiong@ 声明 本文档编写、制作过程中得到了疯狂Java联盟、以及笔者学习工作过程大量朋友的支持,大家都抱着一个目的:为国内软件 软件开发事业作出绵薄贡献。 我们在此郑重宣布,本*档遵循Apache 2.0协议。在完整保留全部文本(包括本版权页),并且不

7、违反Apache 2.0协议的前提 下,允许和鼓励任何人进行全文转载及推广,我们放弃除署名权外的一切权利。 1.1 创建型模式 AbstractFactory ( 抽象工厂 ) FactoryMethod ( 工厂方法 ) Singleton ( 单态模式 ) Builder ( 建造者模式 ) Protot*pe * 原型模式 ) 1.1.1 工厂方法 *义一个用于创建对象的接口,让子类决定实例化哪一个类。FactoryMethod使一个类的实例*延迟到其子类。  适用性 1.当一个类不知道它所必须创建的对象的类的时候。

8、2.当一个类希望由它的子类来指定它所创建的对象的时候。 3.当*将创建对象的职责委托给多个帮助*类中的某一个,并且*希望将哪一个帮助子类是代理者这一信息局部化的时候。  参与者 1.Product 定义工厂方法所创建的对象的接口。 2.ConcreteProduct 实现Product接口。 3.Creator 声明工厂方法,该方法返回一个Product类型的对象* Creator也可以定义一个工厂方法的缺省实现,它返回一个缺省的ConcreteProduct对象。

9、 可以调用工厂方法以创建一个Product对象。 4.ConcreteCreator 重定义工厂方法以返回一个ConcreteProduct实例。  类图  例子 product public interface Work { void doWork(); } ConcreteProduct public class StudentWork implements Work { public void doWork() { System.out.println("学生*作业!");

10、 } } public class TeacherWork implements Work { public void doWork() { System.out.println("老师审批作业!"); } } Creator public interface IWorkFactory { Work get*ork(); } Concre*eCreator pu*lic class StudentWorkFactory implements IWorkFactory { publ

11、ic Work getWork() { *eturn new StudentWork(); } } public class TeacherWorkFactory implements IWorkFactory { public Work getWork() { return new TeacherWork(); } } Test public class Test { public static void m*in(Strin*[] args) { IWorkFa

12、ctory studentWorkFactory = new StudentWorkFactory(); studentWorkFactory.getWork().d*Work(); IWorkFactory teacherWorkFactory * new TeacherWorkFactory(); teacherWorkFactory.g*tWork().*oWork(); } } result 学生做作业! 老师审批作业! 1.1.2 抽象工厂 提供一个创建一系列相关或相

13、互依赖对象的接口,而无需指定它们具体的类。  适用性 1.一个系统要独立于它的*品的创建、组合和表示时。 2.一个系统要由多个产品系列中的一个来配置时。 3.当你要强调一系列相关的产品对象的设计以便进行联合使用时* 4*当你提供一个产品类库,而只想显示它们*接口而不是实现时。  参与者 1.Ab*tractFactory 声明一个创建抽象产品对象的操作接口。 2.ConcreteFactory 实现创建具体产品对象的操作。 *.AbstractProduc

14、t 为一类产品对象声明一个接口。 4.ConcreteProdu*t 定义一个将被相应的具体工厂创建的产品*象。 实现*bstractProduct接口。 5.Client 仅使用由AbstractFactory和AbstractProduc*类声明的接口  类图  例子 *bstractFactory public interface IAn*malFactory { ICat createCat(); IDog cre*teDog(); } Concret

15、eFactory p*blic class BlackAnimalFactory implem*nts IAnimalFactory { public ICat createCat() { retur* new BlackCat(); } public IDog createDog() { return new BlackDog(); } } public class WhiteAnimalFac*ory imp*ements IAnimalFactory { public I

16、Cat createCat() { return new WhiteCat(); } public IDog cre*teDog() { return new WhiteDog(); } } Abstrac*Product public interface ICat { void eat(); } public interface IDog { void eat(); } Concrete*roduct public class Black*at impleme

17、nts ICat { public void eat() { System.out.println("The bl*ck cat is eating!"); } } public class WhiteCat implements *Cat { public void eat() { Sy*tem.out.prin*ln("The w*ite cat is eating!*); } } public class BlackDog implements IDog { publ

18、ic void eat() { System.out.println("The black dog is eating"); } } public class WhiteDog implements IDog { public void eat() { System.out.println("The white dog is eat*ng!"); } } Client public static void main(String[] args) { IAnimalFactory blac

19、kAnimalFa*tory = new BlackAnimalFactory(); ICat blackCat = blackAnimalFactory.createCat(); blackCat.eat(); IDog blackD*g = blackAnimalFactory.createDog(); blackDog.eat(); IAnimalFactory whiteAnimalF*ctory = new WhiteAnimalFactory(); ICat whiteCat = whiteAnimalFact

20、ory.createCat(); whiteCat.eat(); IDog *hiteDog = whiteAnimalFactory.createDog(); whiteDog.eat(); } res*lt The bla*k cat is eating! Th* black dog is eatin*! The white cat is eating! The white dog is *ating! 1.1.3 建造者模式 将一个复杂对象的构*与它的表示分离,使*同样的构建过程可以创建不同的表示。  适用性

21、 1.当创建复杂对象的算法应该独立于该对象的组成部分以及它们的装配方式时。 *.当构造过程必须允*被构造的对象有不同*表示时。  参与者 1.Builder 为创建一个Product对象的各个部件指定抽象接口。 2.ConcreteBuilder 实现Buil*er的接口以构造和装配该产品的各个部件。 定义并明确它所创建的表示* 提供一个检索产品的接口。 3.Director 构造一个使用Builder接口的对象。 4.Product

22、 表示被构造的复杂对象。ConcreteBuilder创建该产品的内部表示并定义它的装配过程。 包含定义组成部件的类,包括将这些部件装配成最终产品的接口。  类图  例子 Buil*er public interface PersonBuilder { void buildHead(); v*id buildBody(); void buildFoot()* Person buildPerson(); } ConcreteBuilder public class ManBui

23、lder implements PersonB*ilder { Person person; public ManBuilder() { person = ne* Man(); } publ*c void build*ody() { perso*.setBody("建造男人的身体"); } public void buildFoot() { person.setFo*t("建造男人的脚"); } public void bui

24、ldHead() { pers*n.setHead("建造*人的头"); } *ublic Person buildPerson() { retur* person; } } Dir*ctor public class PersonDirec*or { public Person constructPerson(PersonBuilder pb) { pb.buildHead(); pb.buildBody(); pb.buildFoot();

25、 return pb.buildPerson(); } } Product public class Person { private String head; private String body; private String foot; public String getH*ad() { return head; } public void setHead(String hea*) { this.head = head

26、 } public String getBody() { return body; } public void setBody(String body) { this.b*dy = body; } public String getFoot() { return foot; } public void setFoot(String foot) { t*is.foot = foot; } } public cl

27、ass Man extends Person { } Test publ*c class Test{ public static void main(String[] ar*s) { PersonDirector pd = new PersonDirector(); Person person = pd.constructPerson(new ManBuilder()); System*out.println(person.getBody()); System.out.println(

28、person.getFoot()); System.out.println(person.getHead()); } } result 建造男人*身体 建造男*的脚 建造男人的头 1.1.4 单态模式 保证一个类仅有一个实例,*提供一个访问它的全局访*点。  适用性 1.当类只能有一个*例而且客户可以从一个众所周知的访问点访问它时。 2.当这个唯一实例应该是通过子类化可扩展的,并且客户应该无需更改代码就能使用一个扩展的实例时。  参与者 Singleton 定义一个

29、Instance操作,允许客户访问它的唯一实例。Instance是一个类操作。 可能负*创建它自己的唯一实例。  类图  例子 Singleton public class Singleton { private static Singleton sing; private Singleton() { } public st*tic Singleton get*nstance() { if (sing == null) { sing

30、 = new Singleto*(); } return sing; } } Test public class Test { public static void *ain(*tring[] args) { Singleton sing = Singleton.getInstance(); Singleton si*g2 = Singleton.getI*stance(); System.out.println(sing);

31、 System.out.pr*ntln(sing2); } } result singleton.Singleton@1c78e57 singleton.Singleton@1c78e57 1.1.5 原型模式 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。  适用性 1.当一个系统应该独立于它的产品创*、构成和表示时。 2.当要实例化的类是在运行时刻指定时,例如,通过动态装载。 3.为了避免创建一个与产品类层次平行的工厂*层次时。 4.当一个类的实例只能有几个不同状态组合中的

32、一种时。 建立相应数目的原型并克隆它们可能比每次用合适的状态手工实例化该类更方便一些。  参与者 1. Prototype 声明一个克隆自身的接口。 2. ConcretePrototype 实现一个克隆自身的操作。 3. Client 让一个原型克*自身从而创建一个新的对象。  类图  例子 Prototype public class Prototype implements Cloneable { private String name;

33、 public void setName(String name) { this.name = name; } public String getName() { return this.name; } public Object clone(){ try { return super.clone(); } catch (Exception e) { e.printStackTrace();

34、 return null; } } } ConcretePrototype publ*c class ConcretePrototype extend* Prototype { public ConcretePrototype(String name) { setName(name); } } Client public clas* Test { public static void main(String[] args) { Prototype pr

35、o = new ConcretePrototy*e("prototype"); Prototype pro2 = (Prototype)pro.clone(); *ystem.out.println(pro.getName()*; System.out.println(pro2.getName()); } } result prototype prototype 1.2 结构型模式 Adapter * 适配器模式 * Bridge ( 桥接模* ) Composite ( 组合模式 ) Decor

36、ator ( 装*模式 ) Facade ( 外观模式 ) Flyweight ( 享元模式 ) Proxy ( 代理模式 ) 1.2.1 适配器模式 将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口*兼容而不能一起工作的那*类可以一起工作。  适用性 1.你想使*一个已经存在的类,而它的接口不符合你的需求。 2.你想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类(即那*接口 可能不一定兼容的类)协同工作。 *.(仅适用于对象Adapter)你想使用一些已经存在的

37、子类,但是不可能对每一个都进行 子类化以匹配它们的接口。对象适配器可以适配它的父类接口。  参与者 1.Target 定义Client使用的与特定领域相关的接口。 2.Client 与符合Target接口的对象协同。 3.Adapt*e 定义一个已经存在的接口,这个接口需要适配。 4.Adapter 对Adaptee的接口与Target接口进行适配  类图  例子 Target public interface Target {

38、 void adapteeMethod(); void adapterMethod(); } Adaptee public class Adaptee { public void adapteeMethod() { Syste*.out.p*intln("Adaptee method!"); } } Adapt*r public clas* Adapter implement* Target { private Adap*ee adaptee; public Adapt

39、er(Adaptee adaptee) { this.adapte* = adaptee; } public void adapteeMethod() { adaptee.adapteeMethod(); } public void adapterMethod() { *ystem.out.println("Adapter method!"); } } Client public cla*s Test { public stati* void main(String[] args) {

40、 Target target = new Adapter(new Adaptee()); tar*et.adapteeMethod(); target.adapterM*thod(); } } result Adaptee method! Adapter method! 1.2.2 桥接模式 将抽象部分与它*实现部分分离,使它们都可以独立地变化。  适用性 1.你不希望在抽*和它的实现部分之间有一个固定的绑定关系。 例如这种情况可能是因为,在程序运行时刻实现部分应可

41、以*选择或者切换。 2.类的抽象以及它的实现都应该可以通*生成子类的方法加以扩充。 这时Bridge模式使你可以对不同的抽象接口和实现部分进行组合,并分别对它们进行扩充。 3.对一个抽象的实现部分的修改应对客户不产生影响,即客户的代码不必重新编译。 4.正如在意图一节的第一个类图中所示的那样,有许多类要生成。 这*一种类层次结构说明你必须将一个对象分解成两个部分。 5.*想在多个对象间共享实现(可能使用引用计数),但同时要求客户并不知*这一点。  参与者 1.Abstraction

42、 定义抽象类的接口。 维护一个指向Implementor类型对象的指针。 2.RefinedAbstraction 扩充由Abstraction定义的接口。 3.Implementor 定义实现类的接口,该接口不一定要与Ab*traction的接口完全一致。 事实上这两个接口可以完全不同。 *般来讲,Implementor接口仅提供基本操作,而Abstraction则定义了基于这些基本操作的较高层次的操作。 4.ConcreteImplementor *现Im

43、plementor接口并定义它的具体实现。  类图  例子 Abstr*ction public abstract class Person { private Clothing clothing; pr*vate String type; public Clothing getClothing() { return clothing; } publi* void setClothing() { this.clothing = *lothingFactory.getC

44、lothing(); } public void setType(String type) { t*is.type = type; } public String getType() { return this.ty*e; } public abstract void dress(); } RefinedAbstraction public class Man extends *erson { public Man() {

45、 setType("男人"); } public void dress() { Clothing clothing = get*lothing(); clothing.personDressCloth(this); } } public class Lady extends Person { public Lady() { setTyp*("女人"); } public void dress() { Cloth*ng

46、clothing = getClothing(); c*othing.personDressCloth(this); } } Implemento* public abstract class Clothing { public abstract void personDressC*oth(*erson person); } ConcreteImplemento* public class *ack*t extends Clothing { public void personDressCloth(Person p

47、erson) { System.out.println(person.getType() + "穿马甲"); } } public cl*ss Trouser extends Clothing { public void personDressCloth(Person person) { System.ou*.println(*erson.getType() + "穿裤子"); } } Test public class Te*t { public s*atic void main(Stri

48、ng[] args) { Person man = new Man(); Person lady = new Lady(); Clothing jacket = new Ja*ket(); Clot*ing trouser = new Trouser(); jacket.personDressCloth(man); trouser.personDressCloth(man);

49、 j*cket.personDressCloth(lady); trouser.personDressCloth(lady); } } result 男人穿马甲 男人穿裤子 女人穿马甲 女人穿裤子 1.2.3 组合模式 将对象组合成树形结构以表示"部分-整体"的层次结构。"Composite使得用户对单个对象和组合对*的使用具有一致性。"  适用性 1.你想表示对象的部分-整*层次结构。 2.你希望用户忽略组合对象与单个对象的不同,用户将统一地使用组合结构中的所有对象。  参与者 1.Component 为组合中的对象声明接口。 在适当的情况下,实现所有类共有接口的缺省行为。 声明一个接口用于访问和管理Component的子组件。 (可选)在递归结构中定义一个接口,用于访问一个父部件,并在合*的情况下实现它。 2.Leaf 在组合中表示叶节点对象,叶节点没有子节点。 在组合中定义节点对象的行为。 3.Compos*te 定义有子部件的*些部件的行为。 存储子部件。 在Component接口中实

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服