创建型
单例(Singleton):私有构造函数,私有静态变量,公有静态函数
简单工厂(Simple Factory):把实例化的操作放到单独的类中,让这个类来决定如何实例化(例如用哪个子类)
工厂方法(Factory Method):在简单工厂中,创建对象的是另一个类,而在工厂方法中,是由子类来创建对象。
抽象工厂(Abstract Factory):抽象工厂模式创建的是对象家族,也就是很多对象而不是一个对象,并且这些对象是相关的,也就是说必须一起创建出来。而工厂方法模式只是用于创建一个对象。
可以这么理解以上三者的关系:简单工厂只有一个工厂类,用户类需要传一个参数进去告诉工厂类如何实例化;工厂方法有许多工厂子类,用户类调用不同子类的方法来进行不同的实例化;抽象工厂不仅有许多工厂子类,每个子类还有许多工厂方法,调用不同子类的不同方法,可以实例化不同的对象:
java1
2
3
4
5
6
7
8
9
10
11
12// 简单工厂
SimpleFactory simpleFactory = new SimpleFactory();
Product product = simpleFactory.createProduct(1);
// 工厂方法
ConcreteFactory concreteFactory = new ConcreteFactory1();
ConcreteProduct product = concreteFactory.createProduct();
// 抽象工厂
AbstractFactory abstractFactory = new ConcreteFactory1();
AbstractProductA productA = abstractFactory.createProductA();
AbstractProductB productB = abstractFactory.createProductB();生成器(Builder):封装一个对象的构造过程。即想要构造一个对象的时候,不再是直接 new,而是调一个函数。
原型模式(Prototype):通过复制原型来构造新对象。
行为型
- 责任链(Chain Of Responsibility):将多个 Request Handler 组织成链的形式,request 在链上传递,而不是使用类似 switch 语句那样直接发给对应的 handler,好处在于新加一个 handler 直接加在链的最后就行了,改动的代码很少。
- 命令(Command):在调用某个对象的方法时,不直接调用,而是调用一个 Command 类的 execute 方法,相当于包了一层,好处在于用户发出的命令(即调用对象的方法)被统一成了 Command 类的方法。
- 解释器(Interpreter):有点像 compiler
- 迭代器(Iterator):字面意思,iterator,提供一种顺序访问聚合对象的元素的方法,并且不暴露聚合对象的内部表示。
- 中介者(Mediator):将相关对象之间复杂的依赖关系变成星系结构,有点像消息队列
- 备忘录(Memento):如果某个类应支持备忘录的功能,需要加上 backup 和 restore 两个方法。
- 观察者(Observer):Observers 订阅 Subject,每当 Subject 更新时,notify 所有订阅了该 Subject 的 Observers
- 状态(State):允许对象在内部状态改变时改变他的行为,有点像状态机。某个类可以持有许多状态类,以及一个当前状态指向某一状态类,这些状态类实现同一个接口,这样当前状态的变化就会带来当前状态对象的方法有不同表现。
- 策略(Strategy):和状态类似,也是允许对象改变自己的行为,但是感觉上有点像状态的子集。因为策略设计模式中,各个状态都是地位对等的策略,改变状态是通过 set 方法直接改变;而状态设计模式中,状态是真正的表示不同的状态,对于不同状态而言,相同的方法可能导致变到不同的状态(状态机)
- 模板方法(Template Method):定义算法框架,并将一些步骤的实现延迟到子类。
- 访问者(Visitor):为一个包含许多对象的复杂结构提供新功能,大致思路是从这个复杂结构的根开始,为所有对象定义 accept 方法,以及它们之间的调用关系,这样用户只需要在复杂结构的根对象上调用 accept 方法,就可以将该结构中每个对象的 accept 方法都调用一遍,而 accept 方法的实现中,就可以加上新功能。
- 空对象(Null):当返回值为某个对象的函数有可能返回 null 时,改为返回一个空对象(与其他可能的返回对象继承自同一类),这样即使不做检查也不会出现空指针异常。
结构型
- 适配器(Adapter):把一个类接口转换成另一个用户需要的接口。
- 桥接(Bridge):如果两个类有关联,并且它们又有许多子类,桥接模式可以将 a*b 的类的数量变为 a+b,本质是将一个类拆成两个可以独立变化的类。
- 组合(Composite):允许用户以相同的方式处理单独对象和组合对象,类比目录结构。
- 装饰器(Decorator):装饰器和被装饰的对象继承自同一类,可以理解成装饰器模式运用了每个组合对象只包含一个对象的组合模式。(开放封闭原则)
- 外观(Facade):提供一个统一的接口,用来访问子系统中的一群接口,从而让子系统更容易使用。(最少知识原则)
- 享元(Flyweight):利用共享的方式来支持大量细粒度的对象,这些对象一部分内部状态是相同的。类比单例模式。
- 代理(Proxy):控制对其他对象的访问,将被代理的对象的方法包了一层,和命令模式不同的是,命令模式的主要目的是将对象的方法统一成 Command 类的方法,而代理模式更多地是在调用被代理对象的方法前做一些处理。尽管两者都会持有子对象。