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

广州手机网站定制信息一个app软件

广州手机网站定制信息,一个app软件,网站建设这个职业,c语言在线编程网站对解释器模式的理解 一、场景1、题目【[来源](https://kamacoder.com/problempage.php?pid1096)】1.1 题目描述1.2 输入描述1.3 输出描述1.4 输入示例1.5 输出示例 二、不采用解释器模式1、代码2、“缺点” 三、采用解释器模式1、代码2、“优点” 四、思考1、解释器模式的意义…

对解释器模式的理解

    • 一、场景
      • 1、题目【[来源](https://kamacoder.com/problempage.php?pid=1096)】
        • 1.1 题目描述
        • 1.2 输入描述
        • 1.3 输出描述
        • 1.4 输入示例
        • 1.5 输出示例
    • 二、不采用解释器模式
      • 1、代码
      • 2、“缺点”
    • 三、采用解释器模式
      • 1、代码
      • 2、“优点”
    • 四、思考
      • 1、解释器模式的意义

一、场景

1、题目【来源】

1.1 题目描述

小明正在设计一个计算器,用于解释用户输入的简单数学表达式,每个表达式都是由整数、加法操作符+、乘法操作符组成的,表达式中的元素之间用空格分隔,请你使用解释器模式帮他实现这个系统。

1.2 输入描述

每行包含一个数学表达式,表达式中包含整数、加法操作符(+)和乘法操作符(*)。 表达式中的元素之间用空格分隔。

1.3 输出描述

对于每个输入的数学表达式,每行输出一个整数,表示对应表达式的计算结果。

1.4 输入示例
2 + 3
5 * 2
3 + 4 * 2
1.5 输出示例
5
10
11

二、不采用解释器模式

1、代码

  • 计算器
public class Calculator {private final Deque<Integer> numberStack;private final Deque<String> operatorStack;public Calculator() {numberStack = new ArrayDeque<>();operatorStack = new ArrayDeque<>();}public Integer calculate(String expression) {if (expression == null || expression.isEmpty()) {return null;}String[] tokens = expression.trim().split("\\s+");for (String token : tokens) {if (isOperator(token)) {while (!operatorStack.isEmpty() && ("*".equals(operatorStack.peek()) && "+".equals(token))) {numberStack.push(numberStack.pop() * numberStack.pop());}operatorStack.push(token);} else {numberStack.push(Integer.parseInt(token));}}while (!operatorStack.isEmpty()) {Integer num2 = numberStack.pop();Integer num1 = numberStack.pop();String operator = operatorStack.pop();if ("+".equals(operator)) {numberStack.push(num1 + num2);} else if ("*".equals(operator)) {numberStack.push(num1 * num2);}}return numberStack.pop();}private static boolean isOperator(String s) {return "+".equals(s) || "*".equals(s);}
}
  • 客户端
public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);Calculator calculator = new Calculator();while (scanner.hasNextLine()) {String expression = scanner.nextLine();System.out.println(calculator.calculate(expression));}}
}

2、“缺点”

  • 倒反天罡了,我觉得不采用解释器模式反而更好。😃

三、采用解释器模式

1、代码

  • 定义表达式
public interface Expression {int interpret();
}public class NumberExpression implements Expression {private final int number;public NumberExpression(int number) {this.number = number;}@Overridepublic int interpret() {return number;}
}public class AddExpression implements Expression {private final Expression left;private final Expression right;public AddExpression(Expression left, Expression right) {this.left = left;this.right = right;}@Overridepublic int interpret() {return left.interpret() + right.interpret();}
}public class MultiplyExpression implements Expression {private final Expression left;private final Expression right;public MultiplyExpression(Expression left, Expression right) {this.left = left;this.right = right;}@Overridepublic int interpret() {return left.interpret() * right.interpret();}
}
  • 计算器
public class Calculator {private final Deque<Expression> expressionStack = new ArrayDeque<>();private final Deque<String> operatorStack = new ArrayDeque<>();public Integer calculate(String expression) {if (expression == null || expression.isEmpty()) {return null;}String[] tokens = expression.trim().split("\\s+");for (String token : tokens) {if (isOperator(token)) {// 处理操作符优先级while (!operatorStack.isEmpty() && ("*".equals(operatorStack.peek()) && "+".equals(token))) {processOperator();}operatorStack.push(token);} else {expressionStack.push(new NumberExpression(Integer.parseInt(token)));}}// 处理剩余的操作符while (!operatorStack.isEmpty()) {processOperator();}// 最终栈中只剩下一个表达式对象return expressionStack.pop().interpret();}private void processOperator() {Expression right = expressionStack.pop();Expression left = expressionStack.pop();String operator = operatorStack.pop();Expression operation;if ("+".equals(operator)) {operation = new AddExpression(left, right);} else if ("*".equals(operator)) {operation = new MultiplyExpression(left, right);} else {throw new IllegalArgumentException("Unknown operator: " + operator);}expressionStack.push(operation);}private static boolean isOperator(String s) {return "+".equals(s) || "*".equals(s);}
}
  • 客户端代码和之前一样

2、“优点”

  • 有种画蛇添足的感觉,貌似没有体现解释器模式的优势。

四、思考

1、解释器模式的意义

  • 抽丝剥茧,从一段简单的代码说起:

public class InterpretTest {public static void main(String[] args) {// 3 + 4 * 2Expression expression = new AddExpression(new NumberExpression(3),new MultiplyExpression(new NumberExpression(4), new NumberExpression(2)));System.out.println(expression.interpret());}
}
  • 当用户输入字符串“3 + 4 * 2”的时候,转换成Expression本身就比较复杂,但一旦转换好了,如上所示,Expression就发挥优势了。

  • 因此,当我们需要解释语法规则时,应该是分为2步的:

    • (1)将字符串类型的表达式,转成Expression对象。
    • (2)Expression对象解释执行。【这一步才体现了解释模式的价值】

    如果不采用解释模式,实际上如同“二、不采用解释器模式”的代码所示,是一边解析表达式字符串,一边执行的。

  • 如果解释执行本身就比较简单(计算器的例子便是如此),先转成Expression对象再解释执行的意义确实不大。

  • 但如果解释执行本身就比较复杂,而且如何解释执行可能变化,这时候解释器模式的价值就体现出来了。

    目前没在实战中遇到过,等遇到了感受就深了。

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

相关文章:

  • 做网站莱芜短视频推广引流方案
  • 建一个商城网站需要多久小程序游戏排行榜2023
  • 购物网站单页模板新媒体如何运营推广
  • 小说盗版网站怎么做郑州seo招聘
  • 网站建设规划模板内江如何做百度的网站
  • 旅游网站开发说明青岛即墨网站网页设计
  • 网站服务器买了后怎么做汕头服饰网站建设
  • 有什么好的提供外链网站lnmp wordpress建设多网站
  • 什么摄像头做直播网站seo技巧与技术
  • 做网站标题居中代码大学生创业项目
  • 网站制作公司哪儿济南兴田德润有活动吗保定企业建站程序
  • 简单响应式网站设计代码龙岗网站维护
  • 北京快速网站建设商城首页网站
  • 内贸网站有多少宣传产品网站
  • 设计网站 f德州网页设计师培训
  • 2018爱情动做网站网站搜索栏怎么做
  • 宁波建站平台上海搬家公司收费价目表2021
  • 网站制作设计教程哈尔滨悦创网络科技网站开发
  • 电商网络营销优化游戏性能的软件
  • 局机关网站建设网站建设与管理的书
  • 湛江网站建设团队网站建设与管理适合女生学吗
  • wordpress人评分插件天津抖音seo
  • 网站右下角图片代码德州网站建设招聘
  • 做网站那些好设计师个人网站架构
  • 去哪网网站设计风格龙港做网站
  • 官网网站搭建需要多少钱天元建设集团有限公司商票拒付
  • 合肥网站建设是什么意思男女做性哪个的小视频网站
  • 建设信用卡积分商城网站西京一师一优课建设网站
  • 网站名称 注册怎么写微信小程序
  • 网站广告收费标准网页制作自我介绍源代码