装饰器模式和代理模式

装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其结构。这种类型的设计模式属于结构型模式,它是作为现有的类的一个包装。

装饰器模式通过将对象包装在装饰器类中,以便动态地修改其行为。

应用:

  • 基础字体-->斜体、加粗、改变字号
  • 武器--->加倍镜、加弹夹
  • 英雄--->升级增加技能
dart 复制代码
public class ADV {
    public static void main(String[] args) {
        Gun98K gun98K = new Gun98K();
        System.out.println(gun98K.getGunDescription());

        // 捡到了一个弹夹
        Magazine magazine = new Magazine(gun98K, 100);
        System.out.println(magazine.getGunDescription());

        // 又捡到了一个倍镜
        OpticalSight opticalSight = new OpticalSight(gun98K, 500);
        System.out.println(opticalSight.getGunDescription());
    }
}
interface Gun {
    int getAttack();
    int getDistance();
    String getGunDescription();
}
class Gun98K implements Gun {
    private String name = "98K";
    private int attack = 100;
    private int distance = 1000;
    @Override
    public int getAttack() {
        return attack;
    }

    @Override
    public int getDistance() {
        return distance;
    }

    @Override
    public String getGunDescription() {
        return name + " 攻击:" + attack + " 距离:" + distance;
    }
}
class GunAK47 implements Gun {
    private String name = "AK47";
    private int attack = 50;
    private int distance = 300;
    @Override
    public int getAttack() {
        return attack;
    }

    @Override
    public int getDistance() {
        return distance;
    }

    @Override
    public String getGunDescription() {
        return name + " 攻击:" + attack + " 距离:" + distance;
    }
}
abstract class Decorator implements Gun {
    protected Gun gun;
    public Decorator(Gun gun) {
        this.gun = gun;
    }
}

// 倍镜
class OpticalSight extends Decorator {
    public OpticalSight(Gun gun) {
        super(gun);
    }

    int distanceAdd;
    public OpticalSight(Gun gun, int distanceAdd) {
        super(gun);
        this.distanceAdd = distanceAdd;
    }

    @Override
    public int getAttack() {
        return gun.getAttack(); // 倍镜不增加攻击力
    }

    @Override
    public int getDistance() {
        return gun.getDistance() + distanceAdd; // 倍镜增加100的距离。
    }

    @Override
    public String getGunDescription() {
        return gun.getGunDescription() + " 倍镜(增加距离:" + distanceAdd + ")";
    }
}

// 弹夹
class Magazine extends Decorator {
    public Magazine(Gun gun) {
        super(gun);
    }

    int attackAdd;
    public Magazine(Gun gun, int attackAdd) {
        super(gun);
        this.attackAdd = attackAdd;
    }
    @Override
    public int getAttack() {
        return gun.getAttack() + attackAdd; // 增加10点攻击力
    }

    @Override
    public int getDistance() {
        return gun.getDistance();
    }

    @Override
    public String getGunDescription() {
        return gun.getGunDescription() + " 弹夹(增加攻击力:" + attackAdd + ")";
    }
}

代理模式和装饰器模式

代理模式和装饰器模式差不多。

代理模式是 "控制访问",装饰器模式是 "增强功能"。

虽然结构上相似(都有一层包装),但意图和场景的差异决定了它们是两种不同的设计模式。

动态代理在spring中有很多应用。

比如AOP、事务管理等。

相关推荐
短剑重铸之日1 天前
《设计模式》第九篇:三大类型之结构型模式
java·后端·设计模式·组合模式·代理模式·结构性模式
B2_Proxy2 天前
如何使用代理服务解决“您的 ASN 被阻止”错误:全面策略分析
网络·爬虫·网络协议·tcp/ip·安全·代理模式
短剑重铸之日3 天前
《设计模式》第六篇:装饰器模式
java·后端·设计模式·装饰器模式
what丶k9 天前
深入理解贪心算法:从原理到经典实践
算法·贪心算法·代理模式
懵萌长颈鹿10 天前
装饰器模式 (Decorator Pattern)
装饰器模式
hrrrrb11 天前
【算法设计与分析】贪心算法
算法·贪心算法·代理模式
进击的小头11 天前
创建型模式:装饰器模式(C语言实战指南)
c语言·开发语言·装饰器模式
懵萌长颈鹿11 天前
代理模式 (Proxy Pattern)
代理模式
小码过河.12 天前
17装饰器模式
开发语言·python·装饰器模式
weixin_4038101312 天前
EasyClick 安卓自动化版本 如何自激活代理模式并且启动安卓的自动化服务
android·自动化·代理模式