当前位置: 首页 > news >正文

Java设计模式之行为型模式(解释器模式)实现方式详解

解释器模式是一种行为型设计模式,用于定义一种语言的文法,并且构建一个解释器来解释该语言中的句子。这种模式常用于处理简单语言的语法解析。

下面是一个简单的例子,使用Java实现一个基本的四则运算表达式求值器(仅支持加减乘除和括号)。

示例场景:

我们希望创建一个简单的数学表达式求值器,它可以解析并计算像 “3 + 5 * (10 - 4)” 这样的字符串表达式。

解释器模式的核心组件包括:

  • 抽象表达式(Abstract Expression): 声明一个抽象的解释操作。
  • 终结符表达式(Terminal Expression): 实现与文法规则中终结符相关的解释操作。
  • 非终结符表达式(Nonterminal Expression): 为文法规则中的非终结符声明一个解释操作。
  • 上下文(Context): 包含解释器之外的一些全局信息。

下面是具体的代码实现:

import java.util.Stack;
// 抽象表达式接口
interface Expression {int interpret();
}
// 终结符表达式:数字
class NumberExpression implements Expression {private final int number;public NumberExpression(int number) {this.number = number;}@Overridepublic int interpret() {return number;}
}
// 非终结符表达式基类:二元操作符
abstract class BinaryOperation implements Expression {protected final Expression leftOperand;protected final Expression rightOperand;public BinaryOperation(Expression leftOperand, Expression rightOperand) {this.leftOperand = leftOperand;this.rightOperand = rightOperand;}
}
// 加法操作
class AddExpression extends BinaryOperation {public AddExpression(Expression leftOperand, Expression rightOperand) {super(leftOperand, rightOperand);}@Overridepublic int interpret() {return leftOperand.interpret() + rightOperand.interpret();}
}
// 减法操作
class SubtractExpression extends BinaryOperation {public SubtractExpression(Expression leftOperand, Expression rightOperand) {super(leftOperand, rightOperand);}@Overridepublic int interpret() {return leftOperand.interpret() - rightOperand.interpret();}
}
// 乘法操作
class MultiplyExpression extends BinaryOperation {public MultiplyExpression(Expression leftOperand, Expression rightOperand) {super(leftOperand, rightOperand);}@Overridepublic int interpret() {return leftOperand.interpret() * rightOperand.interpret();}
}
// 除法操作
class DivideExpression extends BinaryOperation {public DivideExpression(Expression leftOperand, Expression rightOperand) {super(leftOperand, rightOperand);}@Overridepublic int interpret() {if (rightOperand.interpret() == 0) {throw new ArithmeticException("Cannot divide by zero");}return leftOperand.interpret() / rightOperand.interpret();}
}
public class InterpreterPatternDemo {// 表达式的解析方法public static Expression parse(String expression) {Stack stack = new Stack<>();String[] tokens = expression.split("\\s+");for (String token : tokens) {switch (token) {case "+":Expression addRight = stack.pop();Expression addLeft = stack.pop();stack.push(new AddExpression(addLeft, addRight));break;case "-":Expression subRight = stack.pop();Expression subLeft = stack.pop();stack.push(new SubtractExpression(subLeft, subRight));break;case "*":Expression mulRight = stack.pop();Expression mulLeft = stack.pop();stack.push(new MultiplyExpression(mulLeft, mulRight));break;case "/":Expression divRight = stack.pop();Expression divLeft = stack.pop();stack.push(new DivideExpression(divLeft, divRight));break;default:stack.push(new NumberExpression(Integer.parseInt(token)));break;}}return stack.pop();}public static void main(String[] args) {String expression = "3 + 5 * (10 - 4)";Expression parsedExpression = parse(expression.replaceAll("\\(", "").replaceAll("\\)", ""));System.out.println("Parsed expression: " + expression);System.out.println("Result: " + parsedExpression.interpret());}
}

说明:
在这个例子中,我们实现了四种基本的操作:加、减、乘、除。每个操作都被表示为一个实现了 Expression 接口的具体类。通过栈的数据结构,我们可以方便地对表达式进行解析和计算。

http://www.dtcms.com/a/309433.html

相关文章:

  • golang的函数
  • Hutool 的完整 JSON 工具类示例
  • 计算机(电脑)是什么?零基础硬件软件详解
  • FreeSWITCH与Java交互实战:从EslEvent解析到Spring Boot生态整合的全指南
  • WPF中使用iconfont图标
  • 【股票数据API接口02】如何获取股票最新分时交易数据之Python、Java等多种主流语言实例代码演示通过股票数据接口获取数据
  • VR 博物馆:开启文化探索新旅程
  • Python深度解析与爬虫进阶:从理论到企业级实践
  • 自建rustdesk服务器过程记录
  • 宝塔服务器挂载数据盘
  • 在vscode 如何运行a.nut 程序(Squirrel语言)
  • spring boot + mybatis + mysql 只有一个实体类的demo
  • 飞算 JavaAI 中 SQL 另存为脚本功能详解
  • 24 SAP CPI 调用SAP HTTP接口
  • nacos升级tomcat
  • 《C++初阶之STL》【stack/queue/priority_queue容器适配器:详解 + 实现】(附加:deque容器介绍)
  • Eclipse中导入新项目,右键项目没有Run on Server,Tomcat的add and remove找不到项目
  • LangChain框架入门03:PromptTemplate 提示词模板
  • YOLO---04YOLOv3
  • 如何撰写专业的面试邀请函(含模板)
  • PyTorch 应用于3D 点云数据处理汇总和点云配准示例演示
  • 一套视频快速入门并精通PostgreSQL
  • 【PHP】接入百度AI开放平台人脸识别API,实现人脸对比
  • 如何填写PDF表格的例子
  • SQL中的GROUP BY用法
  • vue3使用vue-pdf-embed实现前端PDF在线预览
  • EasyExcel 格式设置大全
  • Qt-----初识
  • Qt 跨平台应用开发经验分享
  • 数据结构:链表(Linked List)