博客
关于我
设计模式之适配器模式
阅读量:706 次
发布时间:2019-03-21

本文共 1656 字,大约阅读时间需要 5 分钟。

Adapter 模式:接口适配器实现模式优化

Adapter 模式(接口适配器模式)是一种软件设计模式,用于解决现有类与新系统或新环境不兼容的问题。这种模式通过创建一个间接将两个不兼容的接口连接起来,从而达成双方的平衡。

Adapter 模式的核心思想是当系统中有类的接口与其他代码不兼容时,通过使用适配器类解决不兼容问题,使得原本无法一起工作的类能够协同工作。这种方法不仅提升了系统的灵活性,还增强了系统的可维护性和可扩展性。

Adapter 模式主要应用于以下场景:

  • 当需要将某些现有的类与其他系统或环境集成时,尤其是当这些类的接口与目标系统的需求不匹配时,Adapter 模式是一个非常有效的解决方案。通过在源系统和目标系统之间设计一个适配器,实现两者的互操作性。

  • 在类的继承关系中,当某些子类缺少一些公共功能或接口时,Adapter 模式可以用来补充这些缺少的功能,使其能够与超类或其他部分的系统无缝对接。

  • Adapter 模式的关键优点包括:

  • 符合单一职责原则:适配器类专注于将源接口转换为目标接口,避免混淆和误用。

  • 符合开闭原则:系统可以自开放,而不必Modified为不支持修改的代码架构,也能支持已有的不兼容的系统接口。

  • 以下是Adapter 模式的实现示例:

    对象适配器示例:

    package com.fen.dou.sjms.adapter;public class ObjectAdapterTest {    public static void main(String[] args) {        Adaptee adaptee = new Adaptee();        Target target = new Adapter(adaptee);        target.output5v();    }}interface Target {    int output5v();}class Adapter implements Target {    private Adaptee adaptee;    public Adapter(Adaptee adaptee) {        this.adaptee = adaptee;    }    @Override    public int output5v() {        int i = adaptee.output220v();         return 5;    }}class Adaptee {    public int output220v() {        return 220;    }}

    类适配器示例:

    package com.fen.dou.sjms.adapter;public class ClassAdapterTest {    public static void main(String[] args) {        Adapter adpater = new Adapter();        adpater.output5v();    }}class Adapter extends Adaptee implements Target {    @Override    public int output5v() {        int i = output220v();        return 5;    }}interface Target {    int output5v();}class Adaptee {    public int output220v() {        return 220;    }}

    通过以上示例可以看出,Adapter 模式允许原本接口不兼容的类或系统通过适配器实现信息透 bridge,实现两者的协同工作。无论是对象适配器还是类适配器,都能够满足适配需求,确保系统的稳定性和兼容性。

    转载地址:http://cggez.baihongyu.com/

    你可能感兴趣的文章
    mysql 创建表,不能包含关键字values 以及 表id自增问题
    查看>>
    mysql 删除日志文件详解
    查看>>
    mysql 判断表字段是否存在,然后修改
    查看>>
    MySQL 到底能不能放到 Docker 里跑?
    查看>>
    mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
    查看>>
    MySQL 加锁处理分析
    查看>>
    mysql 协议的退出命令包及解析
    查看>>
    mysql 参数 innodb_flush_log_at_trx_commit
    查看>>
    mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
    查看>>
    MySQL 命令和内置函数
    查看>>
    mysql 四种存储引擎
    查看>>
    MySQL 在并发场景下的问题及解决思路
    查看>>
    MySQL 基础架构
    查看>>
    MySQL 基础模块的面试题总结
    查看>>
    MySQL 备份 Xtrabackup
    查看>>
    mYSQL 外键约束
    查看>>
    mysql 多个表关联查询查询时间长的问题
    查看>>
    mySQL 多个表求多个count
    查看>>
    mysql 多字段删除重复数据,保留最小id数据
    查看>>
    MySQL 多表联合查询:UNION 和 JOIN 分析
    查看>>