博客
关于我
设计模式之适配器模式
阅读量: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 自增id和UUID做主键性能分析,及最优方案
    查看>>
    Mysql 自定义函数
    查看>>
    mysql 行转列 列转行
    查看>>
    Mysql 表分区
    查看>>
    mysql 表的操作
    查看>>
    mysql 视图,视图更新删除
    查看>>
    MySQL 触发器
    查看>>
    mysql 让所有IP访问数据库
    查看>>
    mysql 记录的增删改查
    查看>>
    MySQL 设置数据库的隔离级别
    查看>>
    MySQL 证明为什么用limit时,offset很大会影响性能
    查看>>
    Mysql 语句操作索引SQL语句
    查看>>
    MySQL 误操作后数据恢复(update,delete忘加where条件)
    查看>>
    MySQL 调优/优化的 101 个建议!
    查看>>
    mysql 转义字符用法_MySql 转义字符的使用说明
    查看>>
    mysql 输入密码秒退
    查看>>
    mysql 递归查找父节点_MySQL递归查询树状表的子节点、父节点具体实现
    查看>>
    mysql 通过查看mysql 配置参数、状态来优化你的mysql
    查看>>
    mysql 里对root及普通用户赋权及更改密码的一些命令
    查看>>
    Mysql 重置自增列的开始序号
    查看>>