首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
如何在 Java 中利用 面向对象的组合模式 构建支持无限递归的动态规则判别引擎

如何在 Java 中利用 面向对象的组合模式 构建支持无限递归的动态规则判别引擎

热心网友
85
转载
2026-05-01

如何在 Ja va 中利用面向对象的组合模式构建支持无限递归的动态规则判别引擎

如何在 Ja va 中利用 面向对象的组合模式 构建支持无限递归的动态规则判别引擎

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

理解组合模式在规则引擎中的核心价值

组合模式的价值,从来不是为了“套用”某个设计模式。它的真正用武之地,在于解决一类非常典型的问题:当规则本身可以嵌套、分组、条件化,并且结构完全不确定时——比如用户自定义的“所有条件都满足”、“任意一个满足”或者“非此即彼”的复杂逻辑,同时还需要一套统一的执行逻辑。这时候,用树形结构来建模就显得再自然不过了。

在 Ja va 中实现这一点,其实并不依赖任何重型框架。关键在于一个巧妙的抽象:把“单个规则”和“规则容器”统一到同一个接口下。这样一来,调用方就完全无需区分眼前的是叶子节点还是分支节点,只管调用即可,整个系统的扩展性和灵活性也就随之而来。

定义统一的 Rule 接口与基础实现

一切的基础,是定义一个顶层的、统一的行为契约。这个契约非常简单:

Rule.ja va

boolean evaluate(Context context);

有了这个契约,我们就可以提供两类具体的实现:

  • 原子规则(Leaf):比如 EqualsRule("status", "active") 或者 GreaterThanRule("age", 18)。它们直接读取上下文中的字段,进行判断,然后返回一个布尔结果,干净利落。
  • 组合规则(Composite):比如 AndRule(List children)OrRule(List children) 或者 NotRule(Rule inner)。它们的 evaluate() 方法会递归地调用所有子规则,再根据逻辑运算符(与、或、非)来聚合最终结果。

你看,通过这样的设计,任意深度的嵌套表达式——比如 AND(OR(A, B), NOT(C))——都能用一个清晰的对象树来表示。更妙的是,未来如果需要增加新的运算符,你只需要新增一个 Composite 类,完全不用修改已有的任何逻辑,这完美符合了“开闭原则”。

支持动态构建与运行时解析

理论模型有了,接下来就得让它“活”起来,能处理用户动态配置的规则。用户通常会用 JSON 或者一套自定义的 DSL 来描述规则,我们的任务就是把这些配置解析成一棵活的 Rule 对象树。

举个例子,解析下面这段 JSON:

{ "type": "and", "children": [ { "type": "eq", "field": "role", "value": "admin" }, { "type": "or", "children": [ { "type": "gt", "field": "score", "value": 90 }, { "type": "lt", "field": "age", "value": 35 } ] } ] }

实现起来并不复杂。我们可以编写一个轻量的 RuleParser,利用工厂方法,根据 JSON 中的 type 字段来创建对应的 Rule 实例。对于 children 这样的嵌套字段,就递归地调用解析器自身。这里有个细节值得注意:每个组合规则在构造时,最好不要立即校验子规则列表是否为空。允许空列表,并为其设定一个默认行为(比如 AND 规则遇到空列表时返回 true,OR 规则返回 false),可以有效避免运行时出现恼人的空指针异常。

执行时避免栈溢出与提升性能

“支持无限递归”听起来很强大,但在真实世界里,无限不等于无限制。嵌套层数一旦过深(比如上百层),Ja va 的调用栈就很可能撑不住,抛出 StackOverflowError。怎么解决?通常有两个思路:

  • 主动防御:在 evaluate() 方法中加入一个深度计数器,一旦超过预设的阈值(例如50层),就主动抛出像 RuleEvaluationException("max depth exceeded") 这样的业务异常,提前终止,避免系统崩溃。
  • 改变执行模型:将隐式的递归调用,改为使用显式的栈(比如 Deque)来手动控制遍历过程。每个栈帧记录当前正在执行的规则和下一个要处理的子规则索引。这种方法不仅完全避免了栈溢出,内存消耗可控,而且在调试和日志记录时会清晰得多。

除了稳定性,性能也是关键。对于那些被高频调用、且计算结果纯函数化的原子规则(即输出只依赖于输入上下文,没有副作用),完全可以引入缓存机制。用一个 CachedRule 包装器,内部通过 WeakHashMap 来缓存最近的评估结果,这里的 ContextKey 可以根据规则依赖的字段哈希值来生成。这能在规则复杂、计算成本高时,带来显著的性能提升。

来源:https://www.php.cn/faq/2400390.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

使用位运算优化多条件状态报告的Java实现方法
编程语言
使用位运算优化多条件状态报告的Java实现方法

基于位运算的容差检测报告优化方案 在工业级数据校验场景中,比如木材尺寸的容差检测,我们常常需要根据多个布尔状态(如厚度、宽度、长度是否合格)来组合生成差异化的提示信息。传统的实现方式,往往是写下一长串的 if-else 分支,来覆盖所有可能的逻辑组合。功能虽然能实现,但问题也很明显:代码重复度高,扩

热心网友
05.01
如何在 Java 中使用 ArrayList.ensureCapacity() 减少由于频繁增删导致的数组重分配
编程语言
如何在 Java 中使用 ArrayList.ensureCapacity() 减少由于频繁增删导致的数组重分配

如何在 Ja va 中使用 ArrayList ensureCapacity() 减少由于频繁增删导致的数组重分配 ensureCapacity() 真的能减少重分配吗? 答案是肯定的,但这里有个关键前提:它只对“新增”操作有效,而且必须在执行大量 add() 之前就调用。至于 remove() 操

热心网友
05.01
如何在 Java 中利用 while 循环实现一个简单的基于时间轮算法的定时任务调度流程
编程语言
如何在 Java 中利用 while 循环实现一个简单的基于时间轮算法的定时任务调度流程

如何在 Ja va 中利用 while 循环实现一个简单的基于时间轮算法的定时任务调度流程 可行但仅适用于学习、嵌入式或教学场景;生产环境应优先选用 HashedWheelTimer、ScheduledThreadPoolExecutor 或 Quartz。 在 Ja va 中,用 while

热心网友
05.01
如何在 Java 中使用 String.matches() 编写带有“零宽断言”的高级正则校验表达式
编程语言
如何在 Java 中使用 String.matches() 编写带有“零宽断言”的高级正则校验表达式

如何在 Ja va 中使用 String matches() 编写带有“零宽断言”的高级正则校验表达式 说起 Ja va 里的 String matches() 方法,很多开发者都踩过同一个坑:它要求正则表达式必须从头到尾、完完整整地匹配整个字符串。这相当于在模式前后自动加上了 ^ 和 $。所以,当

热心网友
05.01
怎么在 Java 中使用 String.format() 实现类似 C 语言的格式化输出
编程语言
怎么在 Java 中使用 String.format() 实现类似 C 语言的格式化输出

怎么在 Ja va 中使用 String format() 实现类似 C 语言的格式化输出 String format() 的基本语法和占位符怎么写 很多从 C 语言转过来的开发者,会下意识地把 printf 那套写法直接搬到 Ja va 里。但这里有个关键区别:Ja va 的 String for

热心网友
05.01

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

我的世界正版账号在哪买
游戏攻略
我的世界正版账号在哪买

我的世界正版账号在哪买?权威平台推荐与安全购买全攻略 想要畅玩《我的世界》的所有游戏内容并享受完整社区支持,一个正版账号是必不可少的入场券。如何挑选靠谱渠道并确保交易安全,是许多玩家关心的首要问题。本文将为您系统梳理主流购买平台,并提供一套可操作的安全指南,助您无忧开启创造之旅。 官方渠道:最安全可

热心网友
05.01
三角洲行动长弓溪谷密码汇总2026有哪些
游戏攻略
三角洲行动长弓溪谷密码汇总2026有哪些

在《三角洲行动》中,长弓溪谷地图的“2026”系列密码是解锁隐藏区域与高级资源的关键。掌握这些密码不仅能开启封锁区域获取强力装备,还能触发专属剧情任务,大幅提升你的游戏体验与探索自由度。 三角洲行动长弓溪谷密码汇总与2026密码获取全攻略 具体而言,长弓溪谷中的“2026密码”通常巧妙地隐藏在地图环

热心网友
05.01
DNF助手雪球活动有哪些注意事项
游戏攻略
DNF助手雪球活动有哪些注意事项

掌握DNF助手雪球活动核心玩法,轻松领取海量游戏奖励 在《地下城与勇士》的冒险旅程中,DNF助手雪球活动为玩家提供了一个绝佳的福利获取渠道。参与这项活动不仅能丰富游戏体验,更能为角色成长积累大量实用资源,有效提升刷图与攻坚副本的效率。 DNF助手雪球活动完整参与指南与核心注意事项 要高效参与活动,首

热心网友
05.01
京剧四大名旦之一是哪位表演艺术家
游戏攻略
京剧四大名旦之一是哪位表演艺术家

京剧作为中国的国粹,孕育了无数杰出的表演艺术大师。其中,梅兰芳、程砚秋、尚小云、荀慧生并称为“京剧四大名旦”,他们的艺术成就举世瞩目。那么,在知识问答或相关测试中,我们如何才能准确识别出哪位是四大名旦之一呢? 如何准确判断哪位表演艺术家属于京剧四大名旦 这既是一个经典的文化常识问题,也是一种有趣的互

热心网友
05.01
王者荣耀空空儿怎么出装
游戏攻略
王者荣耀空空儿怎么出装

王者荣耀空空儿出装与实战教学:掌握高爆发刺客的致胜秘诀 在《王者荣耀》这款游戏中,胜负的天平往往倾斜于对细节的把控。想要精通刺客位,仅有极快的手速是远远不够的,合理的装备搭配和精准的入场时机,才是区分顶级刺客与团队短板的核心要素。本期攻略,我们将深入解析高机动性刺客英雄空空儿,为你详细拆解如何在游戏

热心网友
05.01