通俗易懂,值得收藏的 java 设计模式实战,装饰者模式 之 你不用改变,就让你的能力变强了

简介: 装饰模式指的是在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。

什么是装饰者模式

网络百科如下:

装饰模式指的是在不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。

设计模式和编程语言无关,但是二当家的依然用Java语言去实战举例。


装饰者模式中的角色

在这里插入图片描述

  • 抽象构件(Component)角色:给出一个抽象接口,以规范准备接收附加责任的对象。
  • 具体构件(Concrete Component)角色:定义一个将要接收附加责任的类。
  • 装饰(Decorator)角色:持有一个构件(Component)对象的实例,并实现一个与抽象构件接口一致的接口。
  • 具体装饰(Concrete Decorator)角色:负责给构件对象添加上附加的责任。

抽象构件(Component)角色

用动物接口作为抽象构件(Component)角色,动物会移动,和咬。

package com.secondgod.decorator;

/**
 * 动物
 *
 * 抽象构件(Component)角色
 *
 * @author 二当家的白帽子 https://le-yi.blog.csdn.net/
 */
public interface Animal {
    /**
     * 移动
     */
    void move();

    /**
     * 咬你
     */
    void bite();
}

具体构件(Concrete Component)角色

用会跑会咬的狗狗类作为具体构件(Concrete Component)角色。

package com.secondgod.decorator;

/**
 * 狗
 *
 * 具体构件(Concrete Component)角色
 *
 * @author 二当家的白帽子 https://le-yi.blog.csdn.net/
 */
public class Dog implements Animal {

    @Override
    public void move() {
        System.out.println("狗子跑起来吧。。。。。");
    }

    @Override
    public void bite() {
        System.out.println("狗子生气了,咬你。。。。。");
    }
}

装饰(Decorator)角色

二当家为动物设计了装备,可热插拔,牛得很。

package com.secondgod.decorator;

/**
 * 动物装备
 *
 * 装饰(Decorator)角色
 *
 * @author 二当家的白帽子 https://le-yi.blog.csdn.net/
 */
public abstract class AnimalEquipment implements Animal {
    private Animal animal;

    public AnimalEquipment(Animal animal) {
        this.animal = animal;
    }

    @Override
    public final void move() {
        beforeMove();
        animal.move();
        afterMove();
    }

    @Override
    public final void bite() {
        beforeBite();
        animal.bite();
        afterBite();
    }

    /**
     * 移动前的能力增强
     */
    protected abstract void beforeMove();

    /**
     * 移动后的能力增强
     */
    protected abstract void afterMove();

    /**
     * 咬你前的能力增强
     */
    protected abstract void beforeBite();

    /**
     * 咬你后的能力增强
     */
    protected abstract void afterBite();
}

具体装饰(Concrete Decorator)角色

二当家觉得狗狗跑得有点慢,于是二当家设计了一件动物加速装备,不要太先进哦。

package com.secondgod.decorator;

/**
 * 动物加速装备
 *
 * 具体装饰(Concrete Decorator)角色
 *
 * @author 二当家的白帽子 https://le-yi.blog.csdn.net/
 */
public class AnimalAcceleratorEquipment extends AnimalEquipment {
    public AnimalAcceleratorEquipment(Animal animal) {
        super(animal);
    }

    @Override
    protected void beforeMove() {
        System.out.println("打开加速引擎。。。。。");
    }

    @Override
    protected void afterMove() {
        System.out.println("关闭加速引擎。。。。。");
    }

    @Override
    protected void beforeBite() {

    }

    @Override
    protected void afterBite() {

    }
}

有的小动物会被大的动物欺负,于是二当家的为他们设计一款攻击力增强装备来保护自己,不要太猛哦。

package com.secondgod.decorator;

/**
 * 动物保护装备
 *
 * 具体装饰(Concrete Decorator)角色
 *
 * @author 二当家的白帽子 https://le-yi.blog.csdn.net/
 */
public class AnimalProtectionEquipment extends AnimalEquipment{
    public AnimalProtectionEquipment(Animal animal) {
        super(animal);
    }

    @Override
    protected void beforeMove() {

    }

    @Override
    protected void afterMove() {

    }

    @Override
    protected void beforeBite() {
        System.out.println("安装合金牙套。。。。。");
    }

    @Override
    protected void afterBite() {
        System.out.println("取下合金牙套。。。。。");
    }
}

测试的时候到了

package com.secondgod.decorator;

public class Test {

    public static void main(String[] args) {
        System.out.println("一只善良小狗子散步中。。。。。");
        Animal animal = new Dog();
        System.out.println("一只凶猛大狗出现,前来欺负善良小狗。。。。。");
        System.out.println("赶紧为善良小狗装上保护装备,反击的时候到了。。。。。");
        animal = new AnimalProtectionEquipment(animal);
        animal.bite();
        System.out.println("糟糕了,有点过了,跑路吧,小狗子移动太慢了,装上加速装备。。。。。");
        animal = new AnimalAcceleratorEquipment(animal);
        animal.move();
    }
}

在这里插入图片描述

好了,安全到家,Nice。

如果要是用继承的方式,要多出来很多类:加速不合金的狗子,合金不加速的狗子,又加速又合金的狗子,以后可能还要有加速不合金的猫,合金不加速的猫,又加速又合金的猫。


尾声

为了更明确的说明装饰者模式不增加或减少行为,而是行为的增强,所以装饰角色使用抽象类并且是final方法来举例,这样严格限制了具体装饰角色仅决定如何增强行为,而不改变行为的多少。事实上装饰角色也可以是接口。

装饰者模式太好用了,热插拔,你不用改变,就让你的能力变强了。


非常感谢你阅读本文~
放弃不难,但坚持一定很酷~
希望我们大家都能每天进步一点点~
本文由 二当家的白帽子:https://developer.aliyun.com/profile/sqd6avc7qgj7y 博客原创~

相关文章
|
8月前
|
设计模式 网络协议 数据可视化
Java 设计模式之状态模式:让对象的行为随状态优雅变化
状态模式通过封装对象的状态,使行为随状态变化而改变。以订单为例,将待支付、已支付等状态独立成类,消除冗长条件判断,提升代码可维护性与扩展性,适用于状态多、转换复杂的场景。
994 157
|
8月前
|
设计模式 Java Spring
Java 设计模式之责任链模式:优雅处理请求的艺术
责任链模式通过构建处理者链,使请求沿链传递直至被处理,实现发送者与接收者的解耦。适用于审批流程、日志处理等多级处理场景,提升系统灵活性与可扩展性。
824 2
|
10月前
|
设计模式 缓存 Java
Java设计模式(二):观察者模式与装饰器模式
本文深入讲解观察者模式与装饰器模式的核心概念及实现方式,涵盖从基础理论到实战应用的全面内容。观察者模式实现对象间松耦合通信,适用于事件通知机制;装饰器模式通过组合方式动态扩展对象功能,避免子类爆炸。文章通过Java示例展示两者在GUI、IO流、Web中间件等场景的应用,并提供常见陷阱与面试高频问题解析,助你写出灵活、可维护的代码。
|
8月前
|
安全 Java 开发者
告别NullPointerException:Java Optional实战指南
告别NullPointerException:Java Optional实战指南
353 119
|
9月前
|
存储 前端开发 Java
【JAVA】Java 项目实战之 Java Web 在线商城项目开发实战指南
本文介绍基于Java Web的在线商城技术方案与实现,涵盖三层架构设计、MySQL数据库建模及核心功能开发。通过Spring MVC + MyBatis + Thymeleaf实现商品展示、购物车等模块,提供完整代码示例,助力掌握Java Web项目实战技能。(238字)
1056 0
|
9月前
|
Java 开发者
Java并发编程:CountDownLatch实战解析
Java并发编程:CountDownLatch实战解析
596 100
|
8月前
|
设计模式 算法 搜索推荐
Java 设计模式之策略模式:灵活切换算法的艺术
策略模式通过封装不同算法并实现灵活切换,将算法与使用解耦。以支付为例,微信、支付宝等支付方式作为独立策略,购物车根据选择调用对应支付逻辑,提升代码可维护性与扩展性,避免冗长条件判断,符合开闭原则。
2070 35
|
8月前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
593 8
|
9月前
|
人工智能 Java API
Java AI智能体实战:使用LangChain4j构建能使用工具的AI助手
随着AI技术的发展,AI智能体(Agent)能够通过使用工具来执行复杂任务,从而大幅扩展其能力边界。本文介绍如何在Java中使用LangChain4j框架构建一个能够使用外部工具的AI智能体。我们将通过一个具体示例——一个能获取天气信息和执行数学计算的AI助手,详细讲解如何定义工具、创建智能体并处理执行流程。本文包含完整的代码示例和架构说明,帮助Java开发者快速上手AI智能体的开发。
3325 8
|
9月前
|
人工智能 Java API
Java与大模型集成实战:构建智能Java应用的新范式
随着大型语言模型(LLM)的API化,将其强大的自然语言处理能力集成到现有Java应用中已成为提升应用智能水平的关键路径。本文旨在为Java开发者提供一份实用的集成指南。我们将深入探讨如何使用Spring Boot 3框架,通过HTTP客户端与OpenAI GPT(或兼容API)进行高效、安全的交互。内容涵盖项目依赖配置、异步非阻塞的API调用、请求与响应的结构化处理、异常管理以及一些面向生产环境的最佳实践,并附带完整的代码示例,助您快速将AI能力融入Java生态。
1417 12