适配器模式(Adapter Pattern)———-结构型模式

对象适配器模式的缺点是:与类适配器模式相比,要在适配器中置换适配着类的某些方法比较麻烦。如果一定要置换掉适配者类的一个或多个方法,可以先做一个适配者类的子类,在子类中将适配者类的方法置换掉,然后再把适配者类的子类当做真正的适配着进行适配,实现过程较为复杂。

优点:

1、将目标类和适配者类解耦,通过引入一个适配器类来重用现有的适配者类,无须修改原有的结构。

2、增加了类的透明性和复用性,将具体的业务实现过程封装在适配者类中,对于客户端类而言是透明的,而且提高了适配者类的复用性,同一个适配者类可以在多个不同的系统中复用。

此外,类适配器模式还有如下优点:由于适配器类是适配者类的子类,因此可以在适配器类中置换一些适配者的方法,使得适配器的灵活性更强;

对象适配器模式还有如下优点:1、一个对象适配器可以把多个不同的适配者适配到同一个目标。2、可以适配一个适配者的子类,由于适配器和适配者之间时关联关系,根据里氏替换原则(Liskov Substitution Principle, LSP),适配者的子类以可通过该适配器进行适配。

 

缺省适配器模式:

适配器模式(Adapter Pattern)----------结构型模式

适用于不想使用一个接口中的所有方法的情况,又称为单接口适配器模式:

在缺省适配器模式中包含3个角色

1、ServiceInterface(适配者接口):它是一个接口,通常在该接口中声明了大量的方法

2、AbstractServiceClass(缺省适配器类):它是缺省适配器模式的核心类,使用空方法的形式实现了在ServiceInterface接口中声明的方法。通常将它定义为抽象类,因为对它进行实例化没有任何意义(C++中,将构造函数和析构函数的访问控制权限设置为了protected)

3、ConcreteServiceClass(具体业务类):它时缺省适配器类的子类,在没有引入适配器之前,它需要实现适配者接口,因此需要实现在适配者接口中定义的所有方法,而对于一些无须使用的方法也不得不提供空实现。在有了缺省适配器模式之后,可以直接继承该适配器类,根据需要有选择性的覆盖在适配器类中定义的方法。

 

对象适配器模式:

适配器模式(Adapter Pattern)----------结构型模式

对象适配器模式结构图中包含3个角色:

1、Target(目标抽象类):目标抽象类定义客户所需接口,可以是一个抽象类或接口,也可以是具体类。

2、Adapter(适配器类):适配器可以调用另一个接口,作为一个转换器,对Adapteee和Target进行适配。适配器类是适配器模式的核心,在对象适配器模式中,它通过继承Target并关联一个Adaptee对象使二者产生联系。

3、Adaptee(适配者类):适配者即被适配的角色,它定义了一个已经存在的接口,这个接口需要适配,适配类可以为具体类也可以为接口。

 

类适配器模式:

适配器模式(Adapter Pattern)----------结构型模式

类适配器模式与对象适配器模式最大的区别在于其适配器和适配者之间的关系是继承关系。

 

双向适配器模式:

适配器模式(Adapter Pattern)----------结构型模式

原文链接: https://www.cnblogs.com/openix/p/3189104.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍

    适配器模式(Adapter Pattern)----------结构型模式

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/95846

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年2月10日 上午3:17
下一篇 2023年2月10日 上午3:17

相关推荐