责任链模式+策略模式在项目中的实践

1. 责任链模式实现分析

核心组件
  1. IProcessRule 接口

    • 定义责任链节点行为:filter(过滤逻辑)和 next(获取下一节点)。
    • 符合责任链的"处理-传递"模式。
  2. AbstractProcessRule 抽象类

    • 实现公共逻辑:处理链式调用(若当前规则过滤后仍有多个候选,继续调用下一个规则)。
    • 子类只需实现 doFilter 方法,聚焦具体规则逻辑,符合 模板方法模式
  3. 具体规则类(如 DistanceRule

    • 继承 AbstractProcessRule,实现 doFilter 方法,例如按距离排序。
责任链执行流程
复制代码
// 示例:构建责任链
IProcessRule chain = new DistanceRule(new ScoreRule(new CapacityRule(null)));

// 执行过滤
List<ServeProviderDTO> candidates = chain.filter(providers);
  1. 调用 DistanceRule.doFilter() 按距离排序。
  2. 若结果数量 >1,调用 ScoreRule.doFilter() 按评分排序。
  3. 若仍 >1,调用 CapacityRule.doFilter() 按接单能力排序。
  4. 最终返回唯一候选或最终列表。

2. 策略模式与责任链的结合

策略模式的角色
  • 策略接口 :定义派单策略的入口方法(如 DispatchStrategy#dispatch)。

  • 具体策略类 :每个策略对应一组责任链规则。例如:

    复制代码
    public class PriorityDistanceStrategy implements DispatchStrategy {
        private IProcessRule ruleChain;
    
        public PriorityDistanceStrategy() {
            // 策略1的规则链:距离 → 评分
            ruleChain = new DistanceRule(new ScoreRule(null));
        }
    
        @Override
        public ServeProviderDTO dispatch(List<ServeProviderDTO> providers) {
            List<ServeProviderDTO> result = ruleChain.filter(providers);
            return CollUtils.isEmpty(result) ? null : result.get(0);
        }
    }
扩展性优势
  • 新增策略 :创建新类(如 CapacityFirstStrategy)并定义其规则链。
  • 新增规则 :继承 AbstractProcessRule 实现新逻辑,无需修改已有代码。
相关推荐
云烟成雨TD2 分钟前
Spring AI 1.x 系列【33】RAG Advisor 组件与四大分层架构
java·人工智能·spring
yurenpai(27届找实习中)3 分钟前
redis_点评(21.好友关注——关注、取关功能实现;共同关注功能实现)
数据库·redis·缓存
Rick19933 分钟前
索引的排序和分组
数据库·mysql
爱莉希雅&&&4 分钟前
zabbix快速搭建和使用
android·linux·数据库·zabbix·监控
不爱编程的小陈22 分钟前
事务的进化:从MySQL单机事务到TiDB分布式事务的探究
分布式·mysql·tidb
JohnYan24 分钟前
工作笔记 - PG分组极值
数据库·后端·postgresql
清溪54926 分钟前
DataEase H2 JDBC-RCE(CVE-2025-32966)复现
数据库·安全
ServBay35 分钟前
不要再盲选了,PostgreSQL、MySQL与SQLite真实性能对比
数据库·mysql·sqlite
Trouvaille ~36 分钟前
【Redis篇】Set 与 Zset:集合运算与排行榜的终极武器
数据库·redis·缓存·set·跳表·后端开发·zset
無限進步D37 分钟前
MySQL 创建和管理表
数据库·mysql