博客
关于我
设计模式之适配器模式
阅读量: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 存储过程每隔一段时间执行一次
    查看>>
    mysql 存在update不存在insert
    查看>>
    Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
    查看>>
    Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
    查看>>
    Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
    查看>>
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>
    mysql 审核_审核MySQL数据库上的登录
    查看>>
    mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
    查看>>
    mysql 导入导出大文件
    查看>>
    MySQL 导出数据
    查看>>
    mysql 将null转代为0
    查看>>
    mysql 常用
    查看>>
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>