23种软件设计模式-中级

设计模式分为三大类∶

创建型模式主要用于创建对象。共五种:工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式。
结构型模式主要用于处理类或对象的组合。共七种:适配器模式、装饰器模式、代理模式、外观模式、桥接模式、组合模式、享元模式。
行为型模式主要用于描述类或对象怎样交互和怎样分配职责。共十一种∶策略模式、模板方法模式、观察者模式、迭代器模式、责任链模式、命令模式、备忘录模式、状态模式、访问者模式、中介者模式、解释器模式。

一、工厂方法模式( Factory Method )

也叫虚拟构造器模式,它定义一个用于创建对象的接口,让子类决定实例化哪一个类,使一个类的实例化延迟到其子类。在工厂方法模式中,工厂父类负责定义创建产品对象的公共接口,而工厂子类则负责生成具体的产品对象,这样做的目的是将产品类的实例化操作延迟到工厂子类中完成,即通过工厂子类来确定究竟应该实例化哪一个具体产品类。
在这里插入图片描述

二、抽象工厂模式(Abstract Factory)

提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。属于对象创建型模式。
抽象工厂模式与工厂方法模式最大的区别:工厂方法模式针对的是一个产品等级结构,而抽象工厂模式则需要面对多个产品等级结构。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

三、单例模式(Singleton)

单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例,这个类称为单例类,它提供全局访问的方法。
例如,一个系统中可以存在多个打印任务,但是只能有一个正在工作的任务。
在这里插入图片描述

四、建造者模式(Builder Pattern、生成器模式)

将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。建造者模式将部件和其组装过程分开,一步一步创建一个复杂的对象。用户只需要指定复杂对象的类型就可以得到该对象,而无须知道其内部的具体构造细节。
在这里插入图片描述
在这里插入图片描述

五、原型模式(Prototype )

用原型实例指定创建对象的种类,并且通过复制这些原型创建新的对象。原型模式允许一个对象再创建另外一个可定制的对象,无须知道任何创建的细节。

在这里插入图片描述
在这里插入图片描述

六、适配器模式(Adapter Class/Object)

将一个类的接口转换成客户希望的另外一个接口。使得原本不相容的接口可以协同工作。
适用性:

  • 想使用一个已经存在的类,而它的接口不符合你的需求。
  • 想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类(即那些接口可能不一定兼容的类)协同工作。

在这里插入图片描述
在这里插入图片描述

七、装饰器模式(Decorator )

动态地给一个对象添加一些额外的职责。提供了用子类扩展功能的一个灵活的替代,但比生成子类更为灵活。
装饰模式可以在不需要创造更多子类的情况下,将对象的功能加以扩展。
在这里插入图片描述

八、代理模式( Proxy )

给某一个对象提供一个代理,并由代理对象控制对原对象的引用。
在这里插入图片描述
在这里插入图片描述

九、外观模式(Facade )

定义了一个高层接口,为子系统中的一组接口提供一个一致的界面,从而简化子系统的使用。
在这里插入图片描述

十、桥接模式(Bridge)

将抽象部分与它的实现部分分离,使它们都可以独立地变化。如果要绘制矩形、圆形、椭圆、正方形,至少需要4个形状类,但是如果绘制的图形需要具有不同的颜色,如红色、绿色、蓝色等。
在这里插入图片描述

十一、组合模式(Composite )☆☆☆☆☆

将对象组合成树形结构以表示“部分-整体”的层次结构。使得用户对单个对象和组合对象的使用具有一致性。
组合模式描述了如何将容器对象和叶子对象进行递归组合,使得用户在使用时无须对它们进行区分,可以一致地对待容器对象和叶子对象。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

十二、享元模式(Flyweight )

提供支持大量细粒度对象共享的有效方法。
面向对象技术可以很好地解决灵活性或可扩展性问题,但在很多情况下需要在系统中增加类和对象的个数。当对象数量太多时,将导致运行代价过高,带来性能下降等问题。
如在一个文档中多次出现相同的图片,则只需要创建一个图片对象,通过在应用程序中设置该图片出现的位置,可以实现该图片在不同地方多次重复显示。
享元模式通过共享技术实现相同或相似对象的重用。

十三、策略模式(Strategy )

定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。
在这里插入图片描述
在这里插入图片描述

十四、模板方法(Template Method )

定义一个操作中的算法的骨架,而将一些步骤延迟到子类中。使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

十五、观察者模式(observer )

定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。
在这里插入图片描述

十六、迭代器模式(lterator)

提供一种方法顺序访问一个聚合对象中各个元素,而又不需暴露该对象的内部表示。
怎样遍历一个聚合对象,又不需要了解聚合对象的内部结构,还能够提供多种不同的遍历方式,这就是迭代器模式所要解决的问题。
在这里插入图片描述

十七、责任链模式(Chain of Responsibility)

使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。
在这里插入图片描述
在这里插入图片描述

十八、命令模式( Command )

将一个请求封装为一个对象,从而使你可用不同的请求对客户进行参数化。对命令进行封装,将发出命令的责任和执行命令的责任分割开。请求的一方不必知道接收请求的一方的接口,也不必知道请求是怎么被接收,以及操作是否被执行、何时被执行,以及是怎么被执行的。
在这里插入图片描述
在这里插入图片描述

十九、备忘录模式

在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到原先保存的状态。
为了使软件更加人性化,对于误操作,需要提供一种类似“后悔药”的机制,让软件可以回到误操作前的状态,因此需要保存用户每一次操作后系统的状态,一旦出现误操作,可以把存储的历史状态取出即可回到之前的状态。
在这里插入图片描述

二十、状态模式(State)

允许一个对象在其内部状态改变时改变它的行为。对象看起来似乎修改了它的类。
在这里插入图片描述
在这里插入图片描述

二十一、访问者模式(Visitor)

表示一个作用于某对象结构中的各元素的操作,它使我们可以在不改变各元素的类的前提下定义作用于这些元素的新操作。
在这里插入图片描述
在这里插入图片描述

二十二、中介者模式(Mediator)

用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
在这里插入图片描述

二十三、解释器模式( Interpreter )

定义语言的文法,并且建立一个解释器来解释该语言中的句子,这里的“语言”意思是使用规定格式和语法的代码。例︰构造一个语言解释器,使得系统可以执行整数间的乘、除和求模运算。如用户输入表达式“3* 4/ 2 %4”,输出结果为2。
在这里插入图片描述
仅供参考

  • 2
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

家乡的落日

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值