这是我参与「第五届青训营 」伴学笔记创作活动的第 10 天
1.认识规则引擎
1.1 规则引擎的定义
规则引擎是一种嵌入式在应用程序中的组件,实现了将业务决策从应用程序代码中分离出来,使用预定义的语义模块编写业务决策。接受数据输入,解释业务规划,并根据业务规则做出业务决策。
解决开发人员重复编码的问题,业务决策与服务本身解耦,提高服务的可维护性,缩短开发路径,提高效率。
1.2 组成部分
数据输入:
支持接受使用预定义的语义编写的规则作为策略集。比如"price>500"接受业务的数据作为执行过程中的参数,比如价格、标签等。
规则理解: 能够按照预先定义的词法、语法、优先级、运算符等正确理解业务规则所表达的语义。
规则执行: 根据执行时输入的参数对策略集中的规则进行正确的解释和执行。同时对规则执行过程中的数据类型进行检查,确保执行结果正确。
1.3 应用场景
风控对抗: 与黑灰产的对抗过程中,策略研发和产品斋艺能够根拓黑灰产特征进行快迪识别和对抗规则引璇作为风控系统的核心,使产研人员能够不断的调整和优化对抗策略,以实现最好的风控识别效未。
活动策略运营: 业务活动的运营需要及时根据用户效果反馈进行运营策略的优化和调整。引入规则引季后,可以将服务代码与业务运营逆辑候耦,说高运营策略的认代效率。方使新玩法的探震和效果验证
数据分析和清洗:在数据分析系统中使用规则引单可以使糠的实现对数据进行整理、渍洗和转换,数据分折师可以根拉不间的蒿求来自定义数据处理的规则,方使快捷的产出所需安的数据。
2.编译原理基本概念
2.1 词法分析
词法分析就是把源代码字符串转换为词法单元(Token)的这个过程。
如何识别Tokon?——有限自动机
有限自动机就是一个状态机,它的状态数量是有限的。该状态机在任何一个状态,基于输入的字符,都能做一个确定的状态转换。
2.2 语法分析
语法分析就是在词法分析的基础上,识别表达式的语法结构的过程。
抽象语法树
表达式的语法结构可以用树来表示,其每个节点(子树)是一个语法单元,这个单元的构成规则就叫"语法"。每个节点还可以有下级节点。
上下文无关语法:
语言句子无需考虑上下文,就可以判断正确性。可以使用巴氏(BNF)来表达。
产生式:
一个表达式可以由另外已知类型的表达式或者符号推导产生。
2.3 类型检查
类型综合:
根据子表达式的类型构造出父表达式的类型。例如,表达式A+B的类型是根据A和B的类型定义的。
编译时检查&运行时检查:
类型检查可以发生在表达式的编译阶段,即在构造语法树的阶段:也可以发生在执行时的阶段。
编译时: 需要提前声明参数的类型,在构造语法树过程中进行类型检查。
执行时: 可以根据执行时的参数输入的值类型,在执行过程中进行类型检查