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

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/4576688.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。

注意事项

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

Java24种设计模式指南.docx

1、java 24种设计模式 设计模式的七大原则开闭原则:对扩展开放、对修改关闭。 1. 单一指责原则:一个类只做一件事。 2. 依赖倒转原则:类似于ioc,采用接口编程。 3. 迪米特原则:高内聚,低耦合。 4. 接口隔离原则:应该使用多个接口,而不是用单一的总接口。 5. 合成复用原则:尽量使用对象组合,而不是继承来达到复用目的。 6. 里氏替换原则:子类可以扩展父类的功能,但不能改变原有的功能。 一、创建型模式(5种)2、命令模式(Command) 将命令包装在对象中,以便可以存储、传递到方法中,并像任何其他 对象一样返回(以命令动作为类名)命令模式可以把发出命令的责任和执

2、行命令的责任分开。 适合场景: 1. 需要通过操作来参数化对象。 2. 想要将操作放入队列中,本地执行操作或远程执行操作时,可以使 用。 3. 想要实现操作回滚功能时。 用例: 1. java. lang. Runnablejavax. swing. Action 3、迭代器模式(Iterator)让你能在不暴露集合底层表现形式(列表、栈和树等)的情况 下遍历集合中所有的元素。 提供一个统一的方式来访问集合中的对象。 适合场景: 1. 当集合背后时复杂的数据结构,希望对客户端隐藏时(处于便利性或安全性) 2. 可以监视程序中重复的遍历代码时希望遍历不同,甚至是无法预知的数

3、据结构时。 用例: 1. IteratorVector 集合 2. set集合4、中介模式(Mediator) 能让你减少对象之间混乱无序的依赖关系。该模式会限制对象之间 的直接交互, 迫使它们通过一个中介者对象进行合作。(用一个中 介对象来封装一系列关于对象交互行为)即使用一个4*间对象来进行消息分发以及减少类之间的直接依赖 适合场景: 1. 当一些对象或其他对象紧密耦合难以对其进行修改时。 2. 当组件过于依赖其他组件而无法在不同应用中复用时。 3. 如果为了能在不同情景下复用一些基本行为,而导致需要被迫创建 大量组件子类时。 用例: 1. mq使用的就是此模式MV

4、C 中的 Controller 2. Executor5、备忘录模式(Memento) 允许在不暴露对象实现细节的情况下保存和恢复对象之前的状态。 即生成对象状态的一个快照,以便对象可以恢复原始状态而不用暴露 自身的内容。 在不破坏封装性的情况下,捕获并保存一个类的内部状态,可以利用 该保存的状态实施恢复操作。 适合场景: 1. 当你需要创建对象状态快照来恢复其之前的状态当直接访问对象的成员变量、get、set时导致封装被突破时 用例: 1. Date对象通过自身内部的一个long值来实现备忘录模式Serializable 6、观察者模式/发布订阅模式(Observer/Li

5、stener)允许你定义一种订阅机制,可在对象事件发生时通知多个“观 察”该对象的其他对象。 适合场景: 1. 当一个对象的改变需要改变其他对象时,或实际对象时事先未知的 或动态变化的时。 2. 当应用中的一些对象必须观察其他对象时。 用例: 1. EventListenertomcat 的 LifeCycleListener 2. 使用zookeeper作为观察者,例如分布式锁、服务发现等7、状态模式(State) 能在一个对象的内部状态变化时改变其行为,使其看上去就像改变了自身所属的类一样。 即允许您在运行时根据内部状态轻松更改对象的行为。 状态模式重点在各状态之间

6、的切换从而做不同的事情,状态模式不同 状态下做的事情不同。 状态模式封装了对象的状态,因为状态是跟对象密切相关的,它不能被重用 适合场景: 1. 如果对象需要根据自身当前状态进行不同行为,同时状态的数量非 常多且与状态相关的代码会频繁变更时。 2. 如果某个类根据成员变量的当前值改变自身行为,从而需要使用大 量的条件语句时。 3. 当相似状态和基于状态转换中存在许多重复代码时8、策略模式(Strategy) 它能让你定义一系列算法,并将每种算法分别放入独立的类 中,以使算法的对象能够相互替换 即将一组算法封装成一系列对象。通过调用这些对象可以灵活的改变程序的功能 策略模式更侧

7、重于根据具体情况选择策略,并不涉及切换。策略模式 做的都是同一件事。 策略模式封装算法或策略,通过从Context中分离出策略或算法,我 们可以重用它们。 适合场景: 1. 想使用对象中各种不同的算法变体,并希望在运行时切换算法时。 2. 如果算法在上下文的逻辑中不是特别重要,使用该模式能将类的业 务逻辑与算法实现细节隔离开来。 3. 当类中使用了复杂条件运算符如:if else,以在同一算法的不同 变体中切换时。 可以用策略模式和工厂模式优化程序中过多的if-else9、模版模式(template) 在超类中定义了一个算法的框架, 允许子类在不修改结构的情况下 重写算法的特定步

8、骤。 即让子类可以重写方法的一部分,而不是整个重写,你可以控制子类 需要重写那些操作. 适合场景: 1. 只希望客户端扩展某个特定的算法步骤,而不是整个算法或其结 构时。 2. 当多个类的算法除了一些细微不同之外几乎完全一样时。 用例: 1. InputStream 类的 skip 或 read 方法我们可以做一个抽象类,某个方法需要子类来实现差异化 10、访问者模式(Visitor) 提供一个方便的可维护的方式来操作一组对象。它使得你在不改变操 作的对象前提下,可以修改或者扩展对象的行为。 它能将算法与其所作用的对象隔离开来。虽然可以在不改变原有类结 构的基础上不断添加新

9、的功能。但是缺点是破坏了封装性适合场景: 1. 需要对一个复杂的对象结构(如对象树)中所有的元素执行某些操 作时。 2. 可使用此模式来清理辅助行为的业务逻辑当某个行为仅在类层次结构中的一些类中有意义,在其他类中没意 义是。 11、空对象模式(Empty)它允许抽象空对象的处理。 用例: 1. Collections 类的 emptyList ()Collections 类的 emptyMapO 2. Collections 类的 emptySet()12、解释器模式(Interpreter) 通常描述为该语言定义语法并使用该语法来解释该格式的语句用例: 1. Pattern

10、类Normalizer 类 2. Format 类更多更详细设计模式请参考:, cn/design patterns-全文完- 1、单例模式(Singleton)保证一个类只有一个实例,并提供一个全局访问点。 有四种单例实现方式: . csdn. net/sumengnan/artic1e/detai1s/1089589042、工厂模式(Factory) 把对象的创建功能交给工厂,达到解耦目的。 适合场景: 1. 无法预知对象确切类别及依赖关系时,可使用。 2. 希望复用现有对象来节省系统资源,而不是每次都创建对象。 3、抽象工厂模式(Abstract Factory)用

11、于创建一系列相关的对象,而无需指定其具体类 适合场景: 1. 如果代码需要与多个不同系列的相关产品交互,由于无法提前获取 相关信息或未来扩展考虑,不希望代码基于产品的具体类来进行构 建的情况下使用。 2. 当有一个基于一组抽象方法的类,且其主要功能不明确时,可以使 用例:spring的BcanF&ctory。和其他任何用于创建对象但返回接口或抽象类的就是此模式。 搭配模式:策略模式4、生成器模式(Builder) 定义一个类来简化复杂对象的创建(分步骤创建)。该类是为了构建 另一个类的实例。 适合场景: 1. 避免“重叠构造函数”的出现。 2. 当希望用代码创建不同形式的产品时

12、使用。 3. 比如订单系统,订单对象就是一个复杂对象,我们就可以build来 做。 用例: SpringApplicationBuilder^ StringBuilder5、原型模式(prototype) 使你能够复制已有对象,而又无需使代码依赖它们所属的类。 适合场景: 1. 创建一个对象的实例非常复杂且耗时时可以使用例如我们的DTO、BO、DO、V0转换时可以使用 用例:spring的bean有单例模式singleton和原型模式prototype (scope=prototype)二、结构型模式(7种) 1、代理模式(Proxy)代理控制着对于原对象的访问(不能直接访问原对

13、象), 并允许在 将请求提交给对象前后进行一些处理。 适合场景: 1. 用于保护原对象用于增强原对象 用例:jdk的Proxy类2、适配器模式(Adapter) 用于新接口和旧接口的适配,使接口不兼容的对象能够相互合作。 适合场景: 1. 希望使用某类,但与接口或其他代码不兼容时使用用例:springmvc 的 HandlerAdaptero 例如 xml 转 json,可以新增 XmlJsonAdapter适配器类内进行转换3、桥接模式(bridge) 将抽象和抽象的具体实现进行解耦,使得抽象和抽象的具体实现可以进行独立变化。并使用组合的方式将多维度的抽象方法联系在一起

14、 适合场景: 1. 想要拆分或重组一个具有多重功能的庞杂类(例如多个能与数据交互的类)可使用。 2. 想在几个纬度上扩展类。 3. 想要在运行是切换不同实现方法。 4、组合模式(composite)可以使用它将对象组合成树状结构,以表示“部分-整体”的层次结 构,并且能像使用独立对象一样使用它们。 让客户端看起来在处理单个对象和对象的组合是平等的,换句话说, 某个类型的方法同时也接受自身类型作为参数。例如Map的putAll (Map)方法\ \ 适合场景: 1. 需要实现树状对象结构时。 2. 希望客户端代码以相同方式处理简单和复杂元素时。 3.

15、 常用于递归操作的优化上实例: 5、外观模式/门面模式(Facade)为一组接口、抽象类或子系统提供简化的接口。并且要求一个子系统 的外部与其内部的通信必须通过一个统一的Facade对象进行。 Facade模式提供一个高层次的接口,使得子系统更易于使用适合场景: 1. 需要一个指向复杂子系统的直接接口,但使用的功能有限时。 2. 子系统组织为多层结构时。 3. 保护子系统的接口,可以使用门面模式只提供某些接口,不提供全 部。 4. 使用Dubbo,向外提供的服务就尽量采用门面模式,然后服务在调 用各种service做聚合实例: 1. tomcat 的 RequestFacadeS

16、LFJ日志就是门面日志 6、装饰模式(Decorator/Wapper) 你通过将对象放入包含行为的特殊封装对象中来为原对象绑定新的行 为。相当于动态的给一个对象附加额外的功能,因此它也是子类化的 一种替代方法。 实例: 1. tomcat 对 request 的包装 ServletRequestWrapper所有的io流包装类 7、享元模式(Flyweight)它摒弃了在每个对象中保存所有数据的方式,通过共享多个对象所 共有的相同状态,让你能在有限的内存容量中载入更多对象。 简单来说就是使用缓存来减小对象的访问时间(使用共享技术实现元 素的共享)适合场景:程序必须支持大量对象且没

17、有足够的内存容量时使用(共 享变量) 实例: 1. 只要用到了缓存,基本都是在使用享元模式三、行为型模式(12种) 1、责任链模式(Chain of Responsibility)将请求沿着处理者链进行发送。收到请求后,每个处理者均可对 请求进行处理,或将其传递给链上的下个处理者。 可以实现解耦。责任链中的对象是同-•接口或抽象类的不同实现。 适合场景: 1. 程序需要用不同的方式处理不同请求,而且请求类型和顺序未知 时。 2. 当必须按照顺序执行多个处理者时。 3. 如果所需处理者及其顺序必须在运行时进行改变时。 用例: 1. servler 中 Filter 过滤器拦截器等

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

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

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

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

gongan.png浙公网安备33021202000488号   

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

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

客服