深入Java设计模式之适配器模式

简介: 深入Java设计模式之适配器模式

适配器模式概念

适配器模式(Adapter Pattern):将一个接口转换成客户希望的另一个接口,使接口不兼容的那些类可以一起工作,其别名为包装器(Wrapper)。适配器模式既可以作为类结构型模式,也可以作为对象结构型模式。

在适配器模式中,我们通过增加一个新的适配器类来解决接口不兼容的问题,使得原本没有任何关系的类可以协同工作。

根据适配器类与适配者类的关系不同,适配器模式可分为对象适配器类适配器两种,在对象适配器模式中,适配器与适配者之间是关联关系;在类适配器模式中,适配器与适配者之间是继承(或实现)关系。

 

类适配器实际应用

Customer期望能通过调用AddressValidator接口isValidAddress方法,从而实现调用USAddress/CAAddress类的验证方法(实现不同验证器的统一调度)。

CAAddress是原来老系统里就存在的类,不能把方法名isValidCanadianAddress直接改为isValidAddress。否者会影响老系统的使用

这时就需要一个适配器CAAddressAdapter继承CAAddress,并且实现接口isValidAddress

Customer的里根据入参来判断是实例化CAAddressAdapter还是USAddress

package com.lzhsite.technology.designPattern.adapter.Address;
public class Customer
{
    public static final String US = "US";
    public static final String CANADA = "CANADA";
    private String address;
    private String name;
    private String zip;
    private String state;
    private String type;
    public Customer(String address, String name, String zip, String state, String type)
    {
        this.address = address;
        this.name = name;
        this.zip = zip;
        this.state = state;
        this.type = type;
    }
    public boolean isValidAddress()
    {
      //Customer期望能通过调用AddressValidator接口isValidAddress方法,从而实现调用USAddress/CAAddress类的验证方法(实现不同验证器的统一调度)。
        //CAAddress是原来老系统里就存在的类,不能把方法名isValidCanadianAddress直接改为isValidAddress。否者会影响老系统的使用
      //这时就需要一个适配器CAAddressAdapter继承CAAddress,并且实现接口isValidAddress
      //Customer的里根据入参来判断是实例化CAAddressAdapter还是USAddress
      AddressValidator addressValidator = getValidator(type);
        return addressValidator.isValidAddress(address, zip, state);
    }
    private AddressValidator getValidator(String customerType)
    {
        AddressValidator addressValidator = null;
        if (customerType.equals(Customer.US))
        {
            addressValidator = new USAddress();
        }
        if (customerType.equals(Customer.CANADA))
        {
            addressValidator = new CAAddressAdapter();
        }
        return addressValidator;
    }
}
package com.lzhsite.technology.designPattern.adapter.Address;
public interface AddressValidator
{
    public boolean isValidAddress(String address, String zip, String state);
}
package com.lzhsite.technology.designPattern.adapter.Address;
public class USAddress implements AddressValidator
{
    public boolean isValidAddress(String address, String zip, String state)
    {
        if (address.trim().length() < 10)
        {
            return false;
        }
        if (zip.trim().length() < 5 || zip.trim().length() > 10)
        {
            return false;
        }
        if (state.trim().length() != 2)
        {
            return false;
        }
        return true;
    }
}
package com.lzhsite.technology.designPattern.adapter.Address;
public class CAAddressAdapter extends CAAddress implements AddressValidator
{
    public boolean isValidAddress(String address, String zip, String state)
    {
        return isValidCanadianAddress(address, zip, state);
    }
}
package com.lzhsite.technology.designPattern.adapter.Address;
public class CAAddress
{
    public boolean isValidCanadianAddress(String address, String pcode, String prvnc)
    {
        if (address.trim().length() < 15)
        {
            return false;
        }
        if (pcode.trim().length() != 6)
        {
            return false;
        }
        if (prvnc.trim().length() < 6)
        {
            return false;
        }
        return true;
    }
}
package com.lzhsite.technology.designPattern.adapter.Address;
public class CAAddress
{
    public boolean isValidCanadianAddress(String address, String pcode, String prvnc)
    {
        if (address.trim().length() < 15)
        {
            return false;
        }
        if (pcode.trim().length() != 6)
        {
            return false;
        }
        if (prvnc.trim().length() < 6)
        {
            return false;
        }
        return true;
    }
}

适配器模式的总结

完整代码

https://gitee.com/lzhcode/maven-parent/tree/master/lzh-technology/src/main/java/com/lzhsite/technology/designPattern/adapter


目录
相关文章
|
29天前
|
设计模式 Java Spring
Java 设计模式之责任链模式:优雅处理请求的艺术
责任链模式通过构建处理者链,使请求沿链传递直至被处理,实现发送者与接收者的解耦。适用于审批流程、日志处理等多级处理场景,提升系统灵活性与可扩展性。
202 2
|
29天前
|
设计模式 网络协议 数据可视化
Java 设计模式之状态模式:让对象的行为随状态优雅变化
状态模式通过封装对象的状态,使行为随状态变化而改变。以订单为例,将待支付、已支付等状态独立成类,消除冗长条件判断,提升代码可维护性与扩展性,适用于状态多、转换复杂的场景。
248 0
|
3月前
|
设计模式 缓存 Java
Java设计模式(二):观察者模式与装饰器模式
本文深入讲解观察者模式与装饰器模式的核心概念及实现方式,涵盖从基础理论到实战应用的全面内容。观察者模式实现对象间松耦合通信,适用于事件通知机制;装饰器模式通过组合方式动态扩展对象功能,避免子类爆炸。文章通过Java示例展示两者在GUI、IO流、Web中间件等场景的应用,并提供常见陷阱与面试高频问题解析,助你写出灵活、可维护的代码。
|
28天前
|
设计模式 算法 搜索推荐
Java 设计模式之策略模式:灵活切换算法的艺术
策略模式通过封装不同算法并实现灵活切换,将算法与使用解耦。以支付为例,微信、支付宝等支付方式作为独立策略,购物车根据选择调用对应支付逻辑,提升代码可维护性与扩展性,避免冗长条件判断,符合开闭原则。
244 35
|
28天前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
209 8
|
6月前
|
设计模式 缓存 安全
【高薪程序员必看】万字长文拆解Java并发编程!(8):设计模式-享元模式设计指南
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中的经典对象复用设计模式-享元模式,废话不多说让我们直接开始。
158 0
|
3月前
|
设计模式 安全 Java
Java设计模式(一):单例模式与工厂模式
本文详解单例模式与工厂模式的核心实现及应用,涵盖饿汉式、懒汉式、双重检查锁、工厂方法、抽象工厂等设计模式,并结合数据库连接池与支付系统实战案例,助你掌握设计模式精髓,提升代码专业性与可维护性。
|
3月前
|
设计模式 XML 安全
Java枚举(Enum)与设计模式应用
Java枚举不仅是类型安全的常量,还具备面向对象能力,可添加属性与方法,实现接口。通过枚举能优雅实现单例、策略、状态等设计模式,具备线程安全、序列化安全等特性,是编写高效、安全代码的利器。
|
6月前
|
设计模式 前端开发 Java
【设计模式】【结构型模式】适配器模式(Adpter)
一、入门 什么是适配器模式? 适配器模式是Java中常用的结构型设计模式,它的核心作用就像现实中的电源转换器一样---让原本不兼容的两个接口能够协同工作。 为什么要用适配器模式? 假设我们需要在电商系
163 10
|
8月前
|
设计模式 Java 数据安全/隐私保护
Java 设计模式:装饰者模式(Decorator Pattern)
装饰者模式属于结构型设计模式,允许通过动态包装对象的方式为对象添加新功能,提供比继承更灵活的扩展方式。该模式通过组合替代继承,遵循开闭原则(对扩展开放,对修改关闭)。