如何使用Golang实现解释器模式_Golang解释器模式表达式解析方法

Go实现解释器模式核心是定义Expression接口和Context上下文,通过终结符(如NumberExpr)与非终结符(如AddExpr、MulExpr)表达式递归解析求值,配合递归下降词法语法分析器支持四则运算、括号及变量。

用 Go 实现解释器模式,核心是把字符串表达式(比如 "3 + 5 * 2")拆解成语法树,再递归求值。它不依赖外部库,靠定义好上下文、终结符/非终结符表达式接口和具体实现,就能完成简单 DSL 的解析与执行。

定义解释器核心接口和上下文

解释器模式围绕 Expression 接口展开,所有表达式(数字、加法、乘法等)都实现它;Context 用于传递运行时变量或状态(如变量名到值的映射)。

  • 定义 Expression 接口,含 Interpret(ctx Context) int 方法
  • Context 可以是简单 map: type Context map[string]int
  • 终结符表达式(如数字字面量)直接返回值;非终结符(如加法)组合子表达式并运算

构建基础表达式类型

从最简单的开始写具体表达式结构体:

  • NumberExpr:封装整数,Interpret 直接返回该数
  • AddExprMulExpr:持两个 Expression 字段,Interpret 分别调用左右子表达式再相加/相乘
  • 支持变量时可加 VarExpr,从 Context 查值,未定义可 panic 或返回默认值

手写简易词法+语法解析器(递归下降)

Go 没有内置 parser generator,但小表达式适合手写递归下降解析器。关键点:

  • 先做词法分析:把输入字符串切分为 token 列表(如 ["3", "+", "5", "*", "2"]),跳过空格,识别数字、运算符、括号
  • 语法分析按优先级分层:ParseExpressionParseTerm(处理 +/-)→ ParseFactor(处理 *//)→ ParsePrimary(处理数字、括号)
  • 遇到 (...) 时递归调用 ParseExpression 解析内部

组合使用并运行示例

把解析和解释串起来:

  • 输入 "3 + 5 * 2" → token 化 → 构建出 AddExpr{left: Num(3), right: MulExpr{Num(5), Num(2)}}
  • 调用根表达式的 Interpret(ctx),递归向下计算,最终得 13
  • 支持变量?传入 Context{"x": 10, "y": 2},解析到 "x + y * 3" 就能正确算出 16

基本上就这些。不需要复杂框架,几十行核心代码就能跑通一个带优先级和括号的四则运算解释器。重点在接口抽象清晰、解析逻辑分层明确——解释器模式的价值不在性能,而在让语法规则变得可读、可扩展、可单元测试。