1. 桥接模式
桥接模式的做法是把变化部分(实现)抽象出来,使变化部分与主类(抽象)分离开来。
比如汽车会有发动机:
桥接模式方便Car和Engine的灵活组合、各自扩展。
2. 过滤器模式 - Filter
过滤器模式允许开发人员使用不同的标准来过滤一组对象。例如定义一系列Criteria对Person列表进行过滤,可以有FemaleCriteria,还可以有AndCreteria、OrCriteria对不同条件进行逻辑组合。常用的java8的filter函数应该就是过滤器模式。
3. 适配器模式
适配器模式把一个类的接口变换成客户端所期待的另一种接口,从而使原本因接口不匹配而无法在一起工作的两个类能够在一起工作。
可以在系统层面使用适配器模式,比如服务A的请求,经过适配器B的适配之后发送给服务C。例子就是我们去国外时需要使用的电源适配器。
4. 组合模式
组合模式中包含单个对象和对象集合,比如文件和目录,他们之间存在整体-部分的关系,同时我们希望用同样的接口操作单个对象和对象集合。文件系统的文件和目录就是组合模式的例子。
对象集合也有operate方法,且该方法会调用集合中各个对象的operate方法。
5. 装饰器模式 Decorator
装饰模式又名包装(Wrapper)模式,装饰模式以对客户端透明的方式扩展对象的功能,在不创建子类的基础上扩展对象功能,是继承关系的一个替代方案。装饰器模式通过创建一个包装对象,来包裹真实对象,装饰对象和真实对象的接口相同,这样客户端无差别的调用;装饰对象会把请求转发给真实对象并加上额外的定制操作。
下面的例子中有一个程序员具备编程的基本技能,然后通过hacker、architecture两个装饰器给他加上新的技能。
和继承相比,装饰模式更加动态,可以对已经存在类随意组合,而类的继承一旦定义完成就无法改变;装饰模式扩展的是对象的功能,而类继承扩展是类的功能。
装饰器模式特点在于增强,被装饰类和装饰类必须实现同一个接口,而且必须持有被装饰的对象,可以无限装饰。代理模式的特点在于隔离,隔离调用类和被调用类的关系,通过一个代理类去调用。
Java中的IO流就使用了装饰者模式,用户在使用的时候,可以任意组装,达到自己想要的效果。
6. 外观模式 - Facade
Facade模式为子系统中的各类、方法提供简明一致的界面,隐藏子系统的复杂性,使子系统更加容易使用。可以比喻为建筑物的外墙,当人们走近建筑物时,他只会看到建筑物的外墙,而不会看到其中的管道,电线等复杂的细节。外观模式体现了封装的思想。
外观模式应用示例:slf4j作为日志接口,实现了调用系统和具体日志框架之间的解耦,调用LoggerFactory.getLogger()时,可以获取logback的logger,也可以获取log4j的logger。
外观模式实现了子系统与客户之间的松耦合。
7. 代理模式
动态代理模式:
和动态代理相对的,是静态代理模式,需要写大量代理代码,灵活性不如动态代理模式。