解释器模式(Interperter),给定一个语言,定义一个语言的文法,并且建立一个解释器来解释该语言中的句子,实际开发中EL表达式或者正则表达式的解释器就是采用这种设计模式。其模式结构如下图。本文使用matlab语言,利用解释器模式来实现后缀表达式的解析

Context.m (环境类,包含解释器之外的一些全局信息)

classdef Context < handle
properties
variables = containers.Map();
end
methods
function put(obj,var,expr)
obj.variables(char(var)) = expr;
end
function expr = lookup(obj,var)
if(obj.variables.isKey(char(var)))
expr = obj.variables(char(var));
else
expr = Expression.empty();
end
end
end
end

Expression.m (抽象表达式)

classdef Expression < handle & matlab.mixin.Heterogeneous
methods(Abstract)
interpret(obj,ctx);
end
end

Plus.m (非终结表达式,加法类)

classdef Plus < Expression
properties
left;
right;
end
methods
function obj = Plus(left,right)
obj.left = left;
obj.right = right;
end
function res = interpret(obj,ctx)
res = obj.left.interpret(ctx) + obj.right.interpret(ctx);
end
end
end

Minus.m (非终结表达式,减法类)

classdef Minus < Expression
properties
left;
right;
end
methods
function obj = Minus(left,right)
obj.left = left;
obj.right = right;
end
function res = interpret(obj,ctx)
res = obj.left.interpret(ctx) - obj.right.interpret(ctx);
end
end
end

Variable.m (非终结表达式,变量类)

classdef Variable < Expression
properties
name
end
methods
function obj = Variable(name)
obj.name = name;
end
function res = interpret(obj,ctx)
if(isempty(ctx.lookup(obj.name)))
res = 0;
else
res = ctx.lookup(obj.name).interpret(ctx);
end
end
end
end

Number.m (终结表达式,数字类)

classdef Number < Expression
properties
number
end
methods
function obj = Number(number)
obj.number = number;
end
function number = interpret(obj,~)
number = obj.number;
end
end
end

Evaluator.m (非终结表达式,解析入口类)

classdef Evaluator < Expression
properties
syntaxTree
end
methods
function obj = Evaluator(expr)
exprs = Expression.empty();
tokens = expr.split(" ");
for i=1:length(tokens)
switch(tokens(i))
case "+"
subexpr = Plus(exprs(end-1),exprs(end));
exprs = exprs(1:end-2);
exprs(end + 1) = subexpr;
case "-"
subexpr = Minus(exprs(end-1),exprs(end));
exprs = exprs(1:end-2);
exprs(end + 1) = subexpr;
otherwise
exprs(end + 1) = Variable(tokens(i));
end
end
obj.syntaxTree = exprs(end);
end
function res = interpret(obj,ctx)
res = obj.syntaxTree.interpret(ctx);
end
end
end

test.m (测试代码)

expr = "w x z + -";
ctx = Context();
ctx.put("w",Number(5));
ctx.put("x",Number(6));
ctx.put("z",Number(4));
eva = Evaluator(expr);
res = eva.interpret(ctx);
disp(res);

参考资料:

https://www.jianshu.com/p/0e7e26bbe204

https://www.cnblogs.com/chenpi/p/5222496.html

Matlab解释器模式的更多相关文章

  1. interpreter(解释器模式)

    一.引子 其实没有什么好的例子引入解释器模式,因为它描述了如何构成一个简单的语言解释器,主要应用在使用面向对象语言开发编译器中:在实际应用中,我们可能很少碰到去构造一个语言的文法的情况. 虽然你几乎用 ...

  2. php实现设计模式之 解释器模式

    <?php /* * 解释器模式:给定一种语言,定义它文法的一种表示,并定义一个解释器,该解释器利用该表示来解释语言中的句子 * */ class Expression { function i ...

  3. [工作中的设计模式]解释器模式模式Interpreter

    一.模式解析 解释器模式是类的行为模式.给定一个语言之后,解释器模式可以定义出其文法的一种表示,并同时提供一个解释器.客户端可以使用这个解释器来解释这个语言中的句子. 以上是解释器模式的类图,事实上我 ...

  4. 解释器模式(Interpreter Pattern)

    定义:给定一种语言,定义他的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中句子. 抽象解释器:声明一个所有具体表达式都要实现的抽象接口(或者抽象类),接口中主要是一个interpre ...

  5. C#设计模式——解释器模式(Interpreter Pattern)

    一.概述 在软件开发特别是DSL开发中常常需要使用一些相对较复杂的业务语言,如果业务语言使用频率足够高,且使用普通的编程模式来实现会导致非常复杂的变化,那么就可以考虑使用解释器模式构建一个解释器对复杂 ...

  6. JAVA 设计模式 解释器模式

    用途 解释器模式 (Interpreter) 定义一个语言,定义它的文法的一种表示. 并定义一个解释器,这个解释器使用该表示来解释语言中的句子. 解释器模式是一种行为型模式. 结构

  7. 深入浅出设计模式——解释器模式(Interpreter Pattern)

    模式动机 如果在系统中某一特定类型的问题发生的频率很高,此时可以考虑将这些问题的实例表述为一个语言中的句子,因此可以构建一个解释器,该解释器通过解释这些句子来解决这些问题.解释器模式描述了如何构成一个 ...

  8. JAVA设计模式之解释器模式

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

  9. 【GOF23设计模式】解释器模式 & 访问者模式

    来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_解释器模式.访问者模式.数学表达式动态解析库式 1.解释器模式Interpreter  2.访问者模式Visitor 

随机推荐

  1. LOJ 2249: 洛谷 P2305: bzoj 3672: 「NOI2014」购票

    题目传送门:LOJ #2249. 题意简述: 有一棵以 \(1\) 号节点为根节点的带边权的树. 除了 \(1\) 号节点的所有节点上都有人需要坐车到达 \(1\) 号节点. 除了 \(1\) 号节点 ...

  2. 05-C#笔记-基本变量

    1. 不支持括号初始化: 2. 支持强制类型转化: 3.运算规则同C++ 参考: http://www.runoob.com/csharp/csharp-variables.html

  3. 每天一道Rust-LeetCode(2019-06-01)

    每天一道Rust-LeetCode(2019-06-01) 坚持每天一道题,刷题学习Rust. 题目描述 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的, ...

  4. 【oracle】根据日、月、年分组

    --根据日期分组--------------------------------------------------- SELECT to_char(to_date(XXXX, 'yyyymmdd') ...

  5. GO 解决使用bee工具,报 bash: bee: command not found

    我最近使用beego时,遇到以下问题:command not found使用vscode时,运行bee run,报以下错 我查到一篇文章csdn,说用拷贝bee.exe方法,我觉得纯扯淡 如何解决? ...

  6. piral 基于typescript 的微前端开发框架

    piral有一个微前端开发框架,功能强大,文档比较全,扩展能力也比较好 包含以下特性: 特性 高度模块化 多框架兼容 支持资源文件的拆分 全局状态管理 独立开发和部署 CLI工具 与同类框架的比较 参 ...

  7. Layui 模板引擎中的 日期格式化

    原文:https://www.jianshu.com/p/948a474b5ed7 原文:https://blog.csdn.net/DCFANS/article/details/92064112 模 ...

  8. PATB1031查验身份证

    这一题遇见的错误有很多,学会了一些知识点 使用了strcpy函数,前是需要复制的数组,后面是被复制的数组 关于字符,如果是非数字可以使用 <='9' && >='0'来判断 ...

  9. for循环的嵌套之打印倒三角的星星

    var str = ''; for(var i = 1; i<=10;i++) { for(var j = i; j<=10;j++) { str = str + '★' ; { str ...

  10. Docer安装及简单使用

    前提条件 如果是CentOS8,可以参考这篇文章centos8.0安装docker Docker 运行在 CentOS 7 上,要求系统为64位.系统内核版本为 3.10 以上. Docker 运行在 ...