解释器模式(Interpreter)

定义

解释器模式(Interpreter),给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。

类图

描述

Expression:抽象表达式,声明一个所有的具体表达式都需要实现的抽象接口;这个接口主要是一个interpret()方法,称做解释操作。

Terminal Expression:终结符表达式,实现了抽象表达式所要求的接口;文法中的每一个终结符都有一个具体终结表达式与之相对应。比如公式R=R1+R2,R1和R2就是终结符,对应的解析R1和R2的解释器就是终结符表达式。

Nonterminal Expression:非终结符表达式,文法中的每一条规则都需要一个具体的非终结符表达式,非终结符表达式一般是文法中的运算符或者其他关键字,比如公式R=R1+R2中,“+"就是非终结符,解析“+”的解释器就是一个非终结符表达式。

Context:环境,它的任务一般是用来存放文法中各个终结符所对应的具体值,比如R=R1+R2,给R1赋值100,给R2赋值200,这些信息需要存放到环境中。

应用场景

首先输入一个加减或乘除的运算公式,比如a+b-c+a或a*b/c*a,再给每个参数赋值,最后根据公式完成运算并得到结果。

    /// <summary>
/// 环境
/// </summary>
public class Context
{
private Dictionary<char, double> variable;
public Dictionary<char, double> Variable
{
get
{
if (this.variable == null)
{
this.variable = new Dictionary<char, double>();
}
return this.variable;
}
}
} /// <summary>
/// 抽象表达式
/// </summary>
public abstract class Expression
{
public abstract double Interpret(Context context);
} /// <summary>
/// 变量,终结符表达式
/// </summary>
public class VariableExpression : Expression
{
private char key;
public VariableExpression(char key)
{
this.key = key;
} public override double Interpret(Context context)
{
return context.Variable[this.key];
}
} /// <summary>
/// 操作符,非终结符表达式
/// </summary>
public abstract class OperatorExpression : Expression
{
protected Expression left;
protected Expression right; public OperatorExpression(Expression left, Expression right)
{
this.left = left;
this.right = right;
}
} public class AddExpression : OperatorExpression
{
public AddExpression(Expression left, Expression right)
: base(left, right)
{ } public override double Interpret(Context context)
{
return this.left.Interpret(context) + this.right.Interpret(context);
}
} public class SubExpression : OperatorExpression
{
public SubExpression(Expression left, Expression right)
: base(left, right)
{ } public override double Interpret(Context context)
{
return this.left.Interpret(context) - this.right.Interpret(context);
}
} public class MulExpression: OperatorExpression
{
public MulExpression(Expression left, Expression right)
: base(left, right)
{ } public override double Interpret(Context context)
{
return this.left.Interpret(context) * this.right.Interpret(context);
}
} public class DivExpression: OperatorExpression
{
public DivExpression(Expression left, Expression right)
: base(left, right)
{ } public override double Interpret(Context context)
{
return this.left.Interpret(context) / this.right.Interpret(context);
}
} public class Calculator
{
private string expression;
private Context context; public Calculator(string expression)
{
this.expression = expression;
this.context = new Context();
} public double Calculate()
{
char[] vars = this.expression.ToCharArray();
foreach (char c in vars)
{
if (c == '+' || c == '-' || c == '*' || c == '/')
{
continue;
}
if (!this.context.Variable.ContainsKey(c))
{
Console.Write(c + "=");
this.context.Variable.Add(c, double.Parse(Console.ReadLine()));
}
}
Expression left = new VariableExpression(vars[]);
Expression right = null;
Stack<Expression> stack = new Stack<Expression>();
stack.Push(left);
for (int i = ; i < vars.Length; i += )
{
left = stack.Pop();
right = new VariableExpression(vars[i + ]);
switch (vars[i])
{
case '+':
stack.Push(new AddExpression(left, right));
break;
case '-':
stack.Push(new SubExpression(left, right));
break;
case '*':
stack.Push(new MulExpression(left, right));
break;
case '/':
stack.Push(new DivExpression(left, right));
break;
}
}
double value = stack.Pop().Interpret(this.context);
stack.Clear();
return value;
}
}

输入公式:a+b-c+a

赋值:

a=10
b=5
c=3

运算结果:22

设计模式之笔记--解释器模式(Interpreter)的更多相关文章

  1. 设计模式 笔记 解释器模式 Interpreter

    //---------------------------15/04/26---------------------------- //Interpreter 解释器模式----类行为型模式 /* 1 ...

  2. 《JAVA设计模式》之解释器模式(Interpreter)

    在阎宏博士的<JAVA与模式>一书中开头是这样描述解释器(Interpreter)模式的: 解释器模式是类的行为模式.给定一个语言之后,解释器模式可以定义出其文法的一种表示,并同时提供一个 ...

  3. 学习笔记——解释器模式Interpreter

    解释器模式,其实就是编译原理中的语法解释器,如果用在项目中,可以用于实现动态脚本的解析,也就是说项目可以支持用户脚本扩展. 但实际上,这种运行时解释,效率很慢,如果不是很需要的话,不建议使用. 一种简 ...

  4. 乐在其中设计模式(C#) - 解释器模式(Interpreter Pattern)

    原文:乐在其中设计模式(C#) - 解释器模式(Interpreter Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 解释器模式(Interpreter Pattern) 作 ...

  5. 解释器模式 Interpreter 行为型 设计模式(十九)

      解释器模式(Interpreter)   考虑上图中计算器的例子 设计可以用于计算加减运算(简单起见,省略乘除),你会怎么做?    你可能会定义一个工具类,工具类中有N多静态方法 比如定义了两个 ...

  6. C#设计模式:解释器模式(Interpreter Pattern)

    一,C#设计模式:解释器模式(Interpreter Pattern) 1,解释器模式的应用场合是Interpreter模式应用中的难点,只有满足“业务规则频繁变化,且类似的模式不断重复出现,并且容易 ...

  7. 二十四种设计模式:解释器模式(Interpreter Pattern)

    解释器模式(Interpreter Pattern) 介绍给定一个语言, 定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中的句子. 示例有一个Message实体类,某个类对它的 ...

  8. Java进阶篇设计模式之九----- 解释器模式和迭代器模式

    前言 在上一篇中我们学习了行为型模式的责任链模式(Chain of Responsibility Pattern)和命令模式(Command Pattern).本篇则来学习下行为型模式的两个模式, 解 ...

  9. Java设计模式之九 ----- 解释器模式和迭代器模式

    前言 在上一篇中我们学习了行为型模式的责任链模式(Chain of Responsibility Pattern)和命令模式(Command Pattern).本篇则来学习下行为型模式的两个模式, 解 ...

随机推荐

  1. Qin Shi Huang's National Road System UVA - 1494(次小生成树)

    秦始皇统一中国之后要在全国修公路连接各个城市,皇帝只想修成最小生成树(距离最小,不考虑人力),一个道士说自己可以不花人力物力修一条路,经过两方妥协,选择max(两个城市人口/(生成树长度-这条路的长度 ...

  2. mysql安装使用详细教程

    1.数据库存储数据的方式与Excel类似. 一.数据库介绍 1.什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库, 每个数据库都有一个或多个不同的API用于创建,访 ...

  3. web框架引入

    1. web请求的本质就是一个socket. 2.http:一次请求,一次响应,断开链接.如下程序:必须先运行服务器端,然后客户端才能去连接.所有web框架的本质就是如下: import socket ...

  4. Ajax请求会话过期处理(JS)

    对于页面来说,处理session过期比较简单,一般只需在过滤器里面判断session用户是否存在,不存在则跳转页面到登陆页即可. 对于Ajax请求来说,这个办法则无效,只能获取到登录页的html代码. ...

  5. Tajo--一个分布式数据仓库系统(概述)

    前言:一直对OS X比较仰慕,刚工作送给自己的第一件大礼就是mac pro,嘿嘿.最近在看一个叫tajo得分布式数据仓库,需要依赖protoc 2.4.1,2.5.0都不work,不知道为啥,我在装2 ...

  6. Red Hat下升级python的问题

    分为两部分: 一,升级Python 安装的包的渠道(传送门),安装过程的渠道(传送门). 二.涉及的问题 1.yum不能使用 解决办法(传送门),其中的部分就行.

  7. 洛谷 P4169 [Violet]天使玩偶/SJY摆棋子 解题报告

    P4169 [Violet]天使玩偶/SJY摆棋子 题目描述 \(Ayu\)在七年前曾经收到过一个天使玩偶,当时她把它当作时间囊埋在了地下.而七年后 的今天,\(Ayu\) 却忘了她把天使玩偶埋在了哪 ...

  8. 洛谷 P2233 [HNOI2002]公交车路线 解题报告

    P2233 [HNOI2002]公交车路线 题目背景 在长沙城新建的环城公路上一共有8个公交站,分别为A.B.C.D.E.F.G.H.公共汽车只能够在相邻的两个公交站之间运行,因此你从某一个公交站到另 ...

  9. C++之智能指针20170920

    /*************************************************************************************************** ...

  10. maven私服Nexus3.2的使用

    maven搭建私服的步骤: 分三步: 第一步:下载maven的安装包,然后配置好maven的环境变量. 第二步:将maven的私服Nexus安装好,修改maven的配置文件setting.xml问,在 ...