设计模式——适配器模式

1. 概述

  将一个类的接口转换成客户但愿的另一个接口。Adapter模式使得本来因为接口不兼容而不能一块儿工做的那些类能够在一块儿工做。函数

2. 解决的问题

即Adapter模式使得本来因为接口不兼容而不能一块儿工做的那些类能够在一块儿工做。测试

1、下面是两个很是形象的例子

输入图片说明

输入图片说明

3. 模式中的角色

  • 一 目标接口(Target):客户所期待的接口。目标能够是具体的或抽象的类,也能够是接口。this

  • 二 须要适配的类(Adaptee):须要适配的类或适配者类。code

  • 三 适配器(Adapter):经过包装一个须要适配的对象,把原接口转换成目标接口。   对象

4. 实现方式

  • 1、类的适配器模式(采用继承实现)继承

  • 2、对象适配器(采用对象组合方式实现)接口

5. 适配器模式的类图

输入图片说明

6. 类的适配器模式

// 已存在的、具备特殊功能、但不符合咱们既有的标准接口的类  
    class Adaptee {  
        public void specificRequest() {  
            System.out.println("被适配类具备 特殊功能...");  
        }  
    }  
      
    // 目标接口,或称为标准接口  
    interface Target {  
        public void request();  
    }  
      
    // 具体目标类,只提供普通功能  
    class ConcreteTarget implements Target {  
        public void request() {  
            System.out.println("普通类 具备 普通功能...");  
        }  
    }  
       
    // 适配器类,继承了被适配类,同时实现标准接口  
    class Adapter extends Adaptee implements Target{  
        public void request() {  
            super.specificRequest();  
        }  
    }  
       
    // 测试类public class Client {  
        public static void main(String[] args) {  
            // 使用普通功能类  
            Target concreteTarget = new ConcreteTarget();  
            concreteTarget.request();  
              
            // 使用特殊功能类,即适配类  
            Target adapter = new Adapter();  
            adapter.request();  
        }  
    }

一、测试结果:

普通类 具备 普通功能...  
    被适配类具备 特殊功能...

7. 对象适配器模式

1、状况描述

上面这种实现的适配器称为类适配器,由于 Adapter 类既继承了 Adaptee (被适配类),也实现了 Target 接口(由于 Java 不支持多继承,因此这样来实现),在 Client 类中咱们能够根据须要选择并建立任一种符合需求的子类,来实现具体功能。另一种适配器模式是对象适配器,它不是使用多继承或继承再实现的方式,而是使用直接关联,或者称为委托的方式,类图以下:图片

输入图片说明

2、代码以下:

// 适配器类,直接关联被适配类,同时实现标准接口  
    class Adapter implements Target{  
        // 直接关联被适配类  
        private Adaptee adaptee;  
          
        // 能够经过构造函数传入具体须要适配的被适配类对象  
        public Adapter (Adaptee adaptee) {  
            this.adaptee = adaptee;  
        }  
          
        public void request() {  
            // 这里是使用委托的方式完成特殊功能  
            this.adaptee.specificRequest();  
        }  
    }  
      
    // 测试类  
    public class Client {  
        public static void main(String[] args) {  
            // 使用普通功能类  
            Target concreteTarget = new ConcreteTarget();  
            concreteTarget.request();  
              
            // 使用特殊功能类,即适配类,  
            // 须要先建立一个被适配类的对象做为参数  
            Target adapter = new Adapter(new Adaptee());  
            adapter.request();  
        }  
    }

3、描述

测试结果与上面的一致。从类图中咱们也知道须要修改的只不过就是 Adapter 类的内部结构,即 Adapter 自身必须先拥有一个被适配类的对象,再把具体的特殊功能委托给这个对象来实现。使用对象适配器模式,可使得 Adapter 类(适配类)根据传入的 Adaptee 对象达到适配多个不一样被适配类的功能,固然,此时咱们能够为多个被适配类提取出一个接口或抽象类。这样看起来的话,彷佛对象适配器模式更加灵活一点。ci

8. 模式总结

一 、 优势

一、 经过适配器,客户端能够调用同一接口,于是对客户端来讲是透明的。这样作更简单、更直接、更紧凑。

二、 复用了现存的类,解决了现存类和复用环境要求不一致的问题。

三、 将目标类和适配者类解耦,经过引入一个适配器类重用现有的适配者类,而无需修改原有代码。

四、 一个对象适配器能够把多个不一样的适配者类适配到同一个目标,也就是说,同一个适配器能够把适配者类和它的子类都适配到目标接口。

2、 缺点

一、对于对象适配器来讲,更换适配器的实现过程比较复杂。

3、 适用场景

一、系统须要使用现有的类,而这些类的接口不符合系统的接口。

二、想要创建一个能够重用的类,用于与一些彼此之间没有太大关联的一些类,包括一些可能在未来引进的类一块儿工做。

三、两个类所作的事情相同或类似,可是具备不一样接口的时候。

四、旧的系统开发的类已经实现了一些功能,可是客户端却只能以另外接口的形式访问,但咱们不但愿手动更改原有类的时候。

五、使用第三方组件,组件接口定义和本身定义的不一样,不但愿修改本身的接口,可是要使用第三方组件接口的功能。

相关文章
相关标签/搜索