23种设计模式——策略模式:像换口红一样切换你的算法

发布于:2025-06-29 ⋅ 阅读:(14) ⋅ 点赞:(0)

💄 策略模式:像换口红一样切换你的算法 💋

“算法千变万化,我自优雅应对” —— 解锁策略模式的美学智慧

🌟 策略模式:程序界的百变女王

想象你的代码是一位时尚达人:

  • 出门约会涂斩男色唇釉 💋
  • 商务会议用豆沙色口红 👠
  • 周末派对选姨妈色唇膏 🎉
  • 妆容核心始终不变!

策略模式正是这种智慧:

  • 定义算法家族:每种妆容策略
  • 封装每个算法:独立的口红颜色
  • 运行时自由切换:根据场景变换妆容
  • 核心逻辑不变:化妆流程始终如一
客户端
Context 化妆师
策略接口
斩男色策略
豆沙色策略
姨妈色策略

💡 为什么需要策略模式?

传统做法:if-else灾难

public void applyMakeup(String occasion) {
    if ("date".equals(occasion)) {
        // 50行斩男色代码
    } else if ("meeting".equals(occasion)) {
        // 50行豆沙色代码
    } else if ("party".equals(occasion)) {
        // 50行姨妈色代码
    }
    // 添加新场合?继续堆if-else!
}

痛点

  • 代码臃肿如塞爆的化妆包 💄
  • 添加新策略需修改核心类
  • 难以复用独立算法

策略模式:优雅解决方案

// 策略接口
interface LipstickStrategy {
    void applyColor();
}

// 具体策略
class DateRedStrategy implements LipstickStrategy {
    public void applyColor() {
        System.out.println("👩‍❤️‍💋‍👨 涂抹斩男色:柔雾玫瑰调");
    }
}

class MeetingStrategy implements LipstickStrategy {
    public void applyColor() {
        System.out.println("💼 轻点豆沙色:知性裸妆感");
    }
}

// 上下文 - 化妆师
class MakeupArtist {
    private LipstickStrategy strategy;
    
    public void setStrategy(LipstickStrategy strategy) {
        this.strategy = strategy;
    }
    
    public void executeMakeup() {
        strategy.applyColor();
        System.out.println("✨ 完成精致唇妆");
    }
}

// 客户端
public class Client {
    public static void main(String[] args) {
        MakeupArtist artist = new MakeupArtist();
        
        artist.setStrategy(new DateRedStrategy());
        artist.executeMakeup();
        
        artist.setStrategy(new MeetingStrategy());
        artist.executeMakeup();
    }
}

✨ 策略模式的四大魅力点

1. 开闭原则的典范

  • ✅ 新增策略零修改现有代码
  • ✅ 像口红盒添加新色号般自然

2. 消灭条件判断

  • 🚫 告别switch-case/if-else
  • 🎨 每种算法独立封装

3. 运行时动态切换

  • 🔄 程序运行中自由更换策略
  • ⏱️ 根据实时场景智能选择

4. 算法复用最大化

  • 📦 策略可跨场景复用
  • 🧩 如模块化彩妆盘自由组合

💻 真实场景:电商促销策略

// 促销策略接口
interface DiscountStrategy {
    double applyDiscount(double price);
}

// 具体策略
class ChristmasDiscount implements DiscountStrategy {
    public double applyDiscount(double price) {
        return price * 0.6; // 圣诞6折
    }
}

class MemberDiscount implements DiscountStrategy {
    public double applyDiscount(double price) {
        return price * 0.8; // 会员8折
    }
}

// 支付上下文
class PaymentProcessor {
    private DiscountStrategy strategy;
    
    public void setStrategy(DiscountStrategy strategy) {
        this.strategy = strategy;
    }
    
    public double checkout(double originalPrice) {
        return strategy.applyDiscount(originalPrice);
    }
}

// 使用示例
public class EcommerceDemo {
    public static void main(String[] args) {
        PaymentProcessor processor = new PaymentProcessor();
        
        // 圣诞促销
        processor.setStrategy(new ChristmasDiscount());
        System.out.println("圣诞价: $" + processor.checkout(100));
        
        // 会员促销
        processor.setStrategy(new MemberDiscount());
        System.out.println("会员价: $" + processor.checkout(100));
    }
}

📚 策略模式 vs 状态模式

特性 策略模式 状态模式
目的 算法替换 状态驱动行为改变
变化频率 客户端主动切换 状态自动转换
关系 策略相互独立 状态彼此知晓
类比 主动选择口红颜色 自动转换心情妆容

💼 策略模式面试宝典

Q1:策略模式适用哪些场景?

满分回答

"策略模式特别适合:

  1. 多种算法变体需要动态切换
  2. 需要消除大量条件语句
  3. 算法需要独立复用和扩展
    经典案例:
  • 电商促销折扣策略
  • 导航系统的路径算法
  • 支付网关的支付方式
  • 压缩工具的文件格式处理"

Q2:策略模式有哪些缺点?

专业回答

"需要注意三点:

  1. 客户端需了解策略差异:用户必须知道不同策略的区别
  2. 策略类数量膨胀:每个算法一个类可能产生大量小类
  3. 通信开销:策略与上下文间可能需要传递额外数据
    解决方案:
  • 用工厂模式封装策略创建
  • 合理使用组合减少类数量
  • 精心设计上下文接口"

Q3:策略模式如何提升代码质量?

高阶回答

"策略模式通过:

  1. 提高内聚:每个策略专注单一算法
  2. 降低耦合:上下文不依赖具体实现
  3. 增强扩展:符合开闭原则
  4. 简化测试:每个策略可独立测试
    在Spring中,常用@Qualifier注入不同策略实现"

🧩 设计挑战:旅行路线规划

interface RouteStrategy {
    void calculateRoute(Point start, Point end);
}

class DrivingStrategy implements RouteStrategy {
    public void calculateRoute(Point start, Point end) {
        System.out.println("🚗 计算驾车路线:避开拥堵路段");
    }
}

class WalkingStrategy implements RouteStrategy {
    public void calculateRoute(Point start, Point end) {
        System.out.println("🚶 生成步行路线:优先林荫小道");
    }
}

class PublicTransportStrategy implements RouteStrategy {
    public void calculateRoute(Point start, Point end) {
        System.out.println("🚇 规划公交路线:最少换乘方案");
    }
}

// 任务:实现RoutePlanner上下文类,支持动态切换策略
// 并添加骑行策略(BikingStrategy)

挑战提示

  1. 创建RoutePlanner类持有策略引用
  2. 实现设置策略的方法
  3. 添加执行路线规划的方法
  4. 实现BikingStrategy新策略

💄 美妆启示:策略模式精髓

就像精致妆容需要:

  • 基础打底:策略接口统一规范
  • 色彩选择:具体策略实现变化
  • 工具应用:上下文执行环境

在这里插入图片描述

🌈 总结:优雅应对变化之道

记住策略模式的时尚法则:

  1. 分离变与不变:算法可变,调用方式不变
  2. 拥抱扩展:新策略如新口红般即插即用
  3. 动态切换:运行时自由更换策略
  4. 拒绝臃肿:消灭条件判断语句

程序员美妆箴言:当你的代码需要应对多种"妆容"变化时,策略模式就是最优雅的化妆包!💄✨


网站公告

今日签到

点亮在社区的每一天
去签到