设计模式(Design Pattern)

设计模式(Design Pattern)

  • 概念与定义

    • 是一套被反复使用的、多数人知晓的、经过分类编目的代码设计经验的总结。
    • 设计模式(Design Pattern)是一种对于软件系统中不断重现的设计问题的解决方案进行文档化的技术,也是一种共享专家经验的技术。
    • 设计模式(Design Pattern)是在特定环境下为解决某一通用软件设计问题提供的一套定制的解决方案,该方案描述了对象和类之间的相互作用。
  • 目的与作用

    • 使用设计模式是为了可重用代码、让代码更容易被他人理解并且提高代码的可靠性。

面向对象设计原则

1、单一职责原则(Single Responsibility Principle):一个对象应该只包含单一的职责,并且该职责被完整地封装在一个类中。
2、开闭原则(Open-Closed Principle):软件实体应当对扩展开放,对修改关闭。
3、里氏代换原则(Liskov Substitution Principel):所有引用基类的地方必须能透明地使用其子类的对象。
4、依赖倒转原则(Dependence Inversion Principle):高层模块不应该依赖低层模块,它们都应该依赖抽象。抽象不应该依赖细节,细节应该依赖于抽象。
5、接口隔离原则(Interface Segregation Principle):客户端不应该依赖那些它不需要的接口。
6、合成复用原则(Composite Reuse Principle):优先使用对象组合,而不是通过继承来达到复用的目的。
7、迪米特法则(Law of Demeter):每一个软件单位对其他单位都只有最少的知识,而且局限于那些与本单位密切相关的软件单位。

创建型模式

1、简单工厂模式(Simple Factory Pattern):定义一个工厂类,它可以根据参数的不同返回不同类的实例,被创建的实例通常都具有共同的父类。
2、抽象工厂模式(Abstract Factory Pattern):提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。
3、建造者模式(Builder Pattern):将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。
4、工厂方法模式(Factory Method Pattern):定义一个用于创建对象的接口,但是让子类决定将哪一个类实例化。工厂方法模式让一个类的实例化延迟到其子类。
5、原型模式(Prototype Pattern):使用原型实例指定待创建对象的类型,并且通过复制这个原型来创建新的对象。
6、单例模式(Singleton Pattern):确保一个类只有一个实例,并提供一个全局访问点来访问这个唯一实例。

结构型模式

1、适配器模式(Adapter Pattern):将一个类的接口转换成客户希望的另一个接口。适配器模式让那些接口不兼容的类可以一起工作。
2、桥接模式(Bridge Pattern):将抽象部分与它的实现部分解耦,使得两者都能够独立变化。
3、组合模式(Composite Pattern):组合多个对象形成树形结构以表示具有部分-整体关系的层次结构。组合模式让客户端可以统一对待单个对象和组合对象。
4、装饰模式(Decorator Pattern):动态地给一个对象增加一些额外的职责。就扩展功能而言,装饰模式提供了一种比使用子类更加灵活的替代方案。
5、外观模式(Facade Pattern):为子系统中的一组接口提供一个统一的入口。外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
6、享元模式(Flyweight Pattern):运用共享技术有效地支持大量细粒度对象的复用。
7、代理模式(Proxy Pattern):给某一个对象提供一个代理或占位符,并由代理对象来控制对原对象的访问。

行为型模式

1、职责链模式(Chain of Responsibility Pattern):避免将一个请求的发送者与接收者耦合在一起,让多个对象都有机会处理请求。将接收请求的对象连接成一条链并且沿着这条链传递请求,直到有一个对象能够处理它为止。
2、命令模式(Command Pattern):将一个请求封装为一个对象,从而可用不同的请求对客户进行参数化,对请求排队或者记录请求日志,以及支持可撤销的操作。
3、解释器模式(Interpreter Pattern):给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。
4、迭代器模式(Iterator Pattern):提供一种方法顺序访问一个聚合对象中的各个元素,而又不用暴露该对象的内部表示。
5、中介者模式(Mediator Pattern):定义一个对象来封装一系列对象的交互。中介者模式使各对象之间不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
6、备忘录模式(Memento Pattern):在不破坏封装的前提下捕获一个对象的内部状态,并在该对象之外保存这个状态,这样可以在以后将对象恢复到原先保存的状态。
7、观察者模式(Observer Pattern | Publish/Subscribe Pattern):又称为发布/订阅模式。定义对象之间的一种一对多依赖关系,使得每当一个对象状态发生改变时其相关依赖对象皆得到通知并被自动更新。
8、状态模式(State Pattern):允许一个对象在其内部状态改变时改变它的行为。对象看起来似乎修改了它的类。
9、策略模式(Strategy Pattern):定义一系列算法,将每一个算法封装起来,并让它们可以相互替换。策略模式让算法可以独立于使用它的客户而变化。
10、模板方法模式(Template Method Pattern):定义一个操作中算法的框架,而将一些步骤延迟到子类中。模板方法模式使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
11、访问者模式(Visitor Pattern):表示一个作用于某对象结构中的各个元素的操作。访问者模式可以在不改变各元素的类的前提下定义作用于这些元素的新操作。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

伍嘉源

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

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

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

打赏作者

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

抵扣说明:

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

余额充值