设计模式--适配器模式

适配器模式

适配器模式(Adapter),将一个类的接口转换为客户希望的另一个接口,Adapter模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。

系统的数据和行为都正确,但接口不符合时,我们应该考虑使用适配器,目的是使控制范围之外的一个原有对象与某个接口匹配。适配器模式主要应用于希望复用一些现存的类,但是接口又与复用环境要求不一致的情况。

结构图

  • Target:客户所期待的接口
java 复制代码
public class Target {
    public void request() {
        System.out.println("普通请求");
    }
}
  • Adaptee:需要适配的类
java 复制代码
public class Adaptee {
    public void specificRequest() {
        System.out.println("特殊请求");
    }
}

Adapter:通过在内部包装一个Adaptee对象,把源接口转换成目标接口

java 复制代码
public class Adapter extends Target {
    private Adaptee adaptee = new Adaptee();
    
    public void request() {
        adaptee.specificRequest();
    }
}
  • 客户端
java 复制代码
Target target = new Adapter();
target.request();

案例

有一场篮球比赛,一队的参赛人员,人员五湖四海,还有外籍的,那么就需要一个翻译(适配器)

人员分为:前锋,中锋,后卫,设置一个球员类,需要进攻和防守的方法即可。

java 复制代码
public abstract class Player {
    protected String name;

    public Player(String name) {
        this.name = name;
    }
    
    abstract void attack(); // 进攻
    abstract void defense(); // 防守
}
  • 前锋,中锋,后卫
java 复制代码
// 前锋
public class Forwards extends Player {
    public Forwards(String name) {
        super(name);
    }
    @Override
    void attack() {
        System.out.println("前锋 " + this.name + "进攻");
    }

    @Override
    void defense() {
        System.out.println("前锋 " + this.name + "防守");
    }
}
// 中锋
public class Center extends Player {

    public Center(String name) {
        super(name);
    }

    @Override
    void attack() {
        System.out.println("中锋 " + this.name + "进攻");
    }

    @Override
    void defense() {
        System.out.println("中锋 " + this.name + "防守");
    }
}

// 后卫
public class Guards extends Player {
    public Guards(String name) {
        super(name);
    }
    @Override
    void attack() {
        System.out.println("后卫 " + this.name + "进攻");
    }

    @Override
    void defense() {
        System.out.println("后卫 " + this.name + "防守");
    }
}

而现在有一个外籍中锋人员,我们还需要给他个翻译。

java 复制代码
// 外籍中锋行为
public class ForeignCenter {
    private String name;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
    public void attackForeign() {
        System.out.println("外籍中锋" + this.name + "进攻");
    }

    public void defenseForeign() {
        System.out.println("外籍中锋" + this.name + "防守");
    }
}
  • 适配器
java 复制代码
public class Translator extends Player {

    private ForeignCenter foreignCenter = new ForeignCenter();
    public Translator(String name) {
        super(name);
        foreignCenter.setName(name);
    }
    @Override
    void attack() {
        foreignCenter.attackForeign();
    }
    @Override
    void defense() {
        foreignCenter.defenseForeign();
    }
}
  • 客户端调用
java 复制代码
Player forwards = new Forwards("张三");
forwards.attack();

Player guards = new Guards("李四");
guards.defense();

Player center = new Translator("Mike");
center.attack();
center.defense();
相关推荐
喵叔哟10 分钟前
重构代码中引入外部方法和引入本地扩展的区别
java·开发语言·重构
尘浮生16 分钟前
Java项目实战II基于微信小程序的电影院买票选座系统(开发文档+数据库+源码)
java·开发语言·数据库·微信小程序·小程序·maven·intellij-idea
闲人一枚(学习中)22 分钟前
设计模式-创建型-抽象工厂模式
设计模式·抽象工厂模式
不是二师兄的八戒39 分钟前
本地 PHP 和 Java 开发环境 Docker 化与配置开机自启
java·docker·php
爱编程的小生1 小时前
Easyexcel(2-文件读取)
java·excel
带多刺的玫瑰1 小时前
Leecode刷题C语言之统计不是特殊数字的数字数量
java·c语言·算法
计算机毕设指导62 小时前
基于 SpringBoot 的作业管理系统【附源码】
java·vue.js·spring boot·后端·mysql·spring·intellij-idea
Gu Gu Study2 小时前
枚举与lambda表达式,枚举实现单例模式为什么是安全的,lambda表达式与函数式接口的小九九~
java·开发语言
Chris _data2 小时前
二叉树oj题解析
java·数据结构
牙牙7052 小时前
Centos7安装Jenkins脚本一键部署
java·servlet·jenkins