zoukankan      html  css  js  c++  java
  • 浅谈Java设计模式——适配器模式(Adapter)

    一、概述

            将一个类的接口转换成客户希望的另外一个接口。Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。在我们的应用程序中我们可能需要将两个不同接口的类来进行通信,在不修改这两个的前提下我们可能会需要某个中间件来完成这个衔接的过程。这个中间件就是适配器。所谓适配器模式就是将一个类的接口,转换成客户期望的另一个接口。它可以让原本两个不兼容的接口能够无缝完成对接。作为中间件的适配器将目标类和适配者解耦,增加了类的透明性和可复用性。

    二、使用场景

    1.你想使用一个已经存在的类,而它的接口不符合你的需求。 

    2.你想创建一个可以复用的类,该类可以与其他不相关的类或不可预见的类(即那些接口 可能不一定兼容的类)协同工作。 

    3.(仅适用于对象Adapter)你想使用一些已经存在的子类,但是不可能对每一个都进行 子类化以匹配它们的接口。对象适配器可以适配它的父类接口。

    四、参与者

    1.Target 定义Client使用的与特定领域相关的接口。 

    2.Client 与符合Target接口的对象协同。 

    3.Adaptee 定义一个已经存在的接口,这个接口需要适配。

    4.Adapter 对Adaptee的接口与Target接口进行适配

    五、类图

    六、示例代码

    1.Target:

    /**
     * Target接口
     * @author zhipeng_Tong
     */
    public interface Player {
        void attach();
    
        void defense();
    }

    2.Adapter:

    public class Forward implements Player {
        private String name;
    
        public Forward(String name) {
            this.name = name;
        }
    
        @Override
        public void attach() {
            System.out.println(String.format("前锋 %s 进攻", name));
        }
    
        @Override
        public void defense() {
            System.out.println(String.format("后卫 %s 防守", name));
        }
    }

    /**
     * Adapter
     * @author zhipeng_Tong
     */
    public class Translator implements Player {
        private ForeignCenter foreignCenter;
    
        public Translator(String foreignCenter) {
            this.foreignCenter = new ForeignCenter(foreignCenter);
        }
    
        @Override
        public void attach() {
            foreignCenter.attach();
        }
    
        @Override
        public void defense() {
            foreignCenter.defense();
        }
    }

    3.Adaptee:

    /**
     * Adaptee
     * @author zhipeng_Tong
     */
    public class ForeignCenter {
        private String name;
    
        public ForeignCenter(String name) {
            this.name = name;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public void attach() {
            System.out.println(String.format("外籍中锋 %s 进攻", name));
        }
    
        public void defense() {
            System.out.println(String.format("外籍中锋 %s 防守", name));
        }
    }

    4.测试代码:

    public class Client {
        public static void main(String[] args) {
            Player forward = new Forward("巴蒂尔");
            forward.attach();
    
            Player foreignCenter = new Translator("姚明");
            foreignCenter.attach();
            foreignCenter.defense();
        }
    }

    运行结果:

    前锋 巴蒂尔 进攻
    外籍中锋 姚明 进攻
    外籍中锋 姚明 防守
  • 相关阅读:
    org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'getDataSource' defined in class path resource nested exception is org.springframework.beans.factory.BeanCreat异常
    Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating Caused by: tk.mybatis.mapper.MapperException: 无法获取 cn.itcast.mapper.UserMapper.existsWithPrimaryKey 方法的泛型信息!
    fibnacci数列递归实现
    XOR加密
    Pep8课下作业
    求最大公约数伪代码
    《信息安全专业导论》第五周学习总结
    20191306《信息安全专业导论》第四周学习总结
    用或非门实现其他逻辑门
    寻找黑客偶像
  • 原文地址:https://www.cnblogs.com/IdealSpring/p/11871170.html
Copyright © 2011-2022 走看看