解释器模式(Interpreter Pattern)


解释器模式应用场景比较小,也没有固定的DEMO,中心思想就是自定义解释器用来解释固定的对象

定义:给定一个语言,定义它的文法表示,并定义一个解释器,这个解释器使用该标识来解释语言中的句子。

 

  DEMO的话随便转载了一个写的比较清晰的博主的博客,博主信息如下(代码做了微小修改):

  @Author      风一样的码农
  @HomePageUrl http://www.cnblogs.com/chenpi/
  @Copyright      转载请注明出处,谢谢~

代码:

1、解释器规则:

package com.pat.Interpreter;

import java.util.Map;

/*
* 解释器规则类,本类定义一些语法规则,解释器应用本类中的规则进行解析文本
* @author ZX
*/ /**
* 条件表达式接口,用于解析语法规则
* @author ZX
*/
public interface Expression {
public int interpret(Map<String,Expression> variables);
}
/**
* 数字
*/
class Number implements Expression{
private int number;
@Override
public int interpret(Map<String, Expression> variables) { return number;
}
public Number() {}
public Number(int number) {
this.number=number;
} }
/**
* 加
*/
class Plus implements Expression{
private Expression leftExp;
private Expression rightExp;
@Override
public int interpret(Map<String, Expression> variables) { return leftExp.interpret(variables)+rightExp.interpret(variables);
}
public Plus(){}
public Plus(Expression leftExp,Expression rightExp){
this.leftExp=leftExp;
this.rightExp=rightExp;
}
}
/**
* 减
*/
class Minus implements Expression{
private Expression leftExp;
private Expression rightExp;
@Override
public int interpret(Map<String, Expression> variables) { return leftExp.interpret(variables)-rightExp.interpret(variables);
}
public Minus(){}
public Minus(Expression leftExp,Expression rightExp){
this.leftExp=leftExp;
this.rightExp=rightExp;
} }
/**
* 变量
*/
class Variable implements Expression{
private String name;
@Override
public int interpret(Map<String, Expression> variables) {
if(variables==null) {return 0;}
return variables.get(name).interpret(variables);
}
public Variable(String name) {
this.name=name;
}
}

2、解释器:

package com.pat.Interpreter;

import java.util.Map;
import java.util.Stack;
/**
* 解释器,继承解释器规则类
* @author ZX
* 知识点补充
peek()与pop()
相同点:大家都返回栈顶的值。
不同点:peek 不改变栈的值(不删除栈顶的值),pop会把栈顶的值删除。
*/
public class Evaluator implements Expression{
private Expression syntaxTree; public Evaluator(String expression) {
if(expression==null||"".equals(expression)) {return;}
Stack<Expression> expreStack = new Stack<Expression>();
String[] tokens = expression.split(",");
for(String token:tokens) {
if("+".equals(token)) {
Expression subExpression = new Plus(expreStack.pop(),expreStack.pop());
expreStack.push(subExpression);
}else if("-".equals(token)) {
Expression subExpression = new Minus(expreStack.pop(),expreStack.pop());
expreStack.push(subExpression);
}else {
expreStack.push(new Variable(token));
}
}
syntaxTree=expreStack.pop();
} @Override
public int interpret(Map<String, Expression> variables) {
// TODO Auto-generated method stub
return syntaxTree.interpret(variables);
} }

3、测试类:

package com.pat.Interpreter;

import java.util.HashMap;
import java.util.Map; public class Test {
public static void main(String[] args) {
String expression = "w,x,z,-,+";
Evaluator eva = new Evaluator(expression);
Evaluator sentence = new Evaluator(expression);
Map<String,Expression> variables = new HashMap<String,Expression>();
variables.put("w", new Number(5));
variables.put("x", new Number(10));
variables.put("z", new Number(42));
//求5-10+42
int result = sentence.interpret(variables);
System.out.println(result);
}
}

4、结果:

//求5-10+42  》》》》37

【设计模式】行为型11解释器模式(Interpreter Pattern)的更多相关文章

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

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

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

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

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

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

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

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

  5. 原始的解释器模式(Interpreter Pattern)

    解释器模式的定义(现实项目中非常少遇到,因此直接理论先...) 解释器模式是一种依照规定语法进行解析的方案,在如今项目中使用较少,其定义为:给定一门语言,定义它的方法的一种表示,并定义一个解释器,该解 ...

  6. php解释器模式( interpreter pattern)

    ... <?php /* The interpreter pattern specifies how to evaluate language grammar or expressions. W ...

  7. 十一个行为模式之解释器模式(Interpreter Pattern)

    定义: 定义一个语言的文法,可以使用一个解释器来解释其文法.定义终结符和非终结符的统一接口,并使用抽象对象建立非终结符与其它元素的关联. 结构图: AbstractExpression:抽象表达式类, ...

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

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

  9. Java设计模式(17)解释器模式(Interpreter模式)

    Interpreter定义:定义语言的文法,并且建立一个解释器来解释该语言中的句子. Interpreter似乎使用面不是很广,它描述了一个语言解释器是如何构成的,在实际应用中,我们可能很少去构造一个 ...

随机推荐

  1. 转:spring MVC HTTP406 Not Acceptable

    springMVC框架下,ajax请求,在用json对象返回的时候,可以用如下的形式: response.setContentType("text/html;charset=UTF-8&qu ...

  2. Windows安装Linux子系统--安装GUI界面

    原文:Windows安装Linux子系统--安装GUI界面   前段时间发现Windows可以安装Linux子系统了,恰逢电脑换了固态,还没装Linux,不如趁机体验一番! 1.准备工作 1.1.打开 ...

  3. 像职业选手样编码:地道Python

    Code Like a Pythonista: Idiomatic Python David Goodger goodger@python.org http://python.net/~goodger ...

  4. 细数 Windows Phone 灭亡的七宗罪(过程很详细,评论很精彩,但主要还是因为太慢了,生态跟不上,太贪了,厂商不愿意推广)

    曾梦想仗剑走天涯,看一看世界的繁华 年少的心有些轻狂,如今你四海为家 曾让你心疼的姑娘,如今已悄然无踪影 犹记得上大学攒钱买了第一台智能手机Lumia 520时,下载的第一首歌曲<曾经的你> ...

  5. [转]更改ejs模板后缀.ejs为.html

    三种写法 1,express老写法,3.*已经不支持 app.register('.html', require('ejs')); app.set('view engine', 'ejs'); 2, ...

  6. js 点击超链接,执行js脚本,而不进行url跳转

    <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head><meta ...

  7. WPF应用程序的启动画面[Splash Screen本质分析]

    原文:WPF应用程序的启动画面[Splash Screen本质分析] 不经意间发现了wpf的这个小玩意,感觉蛮有意思的.我在项目中添加了一张图片 如图: wpf-1.JPG(10.73 K) 2010 ...

  8. Qt4可以使用trUtf8函数,其内容可以是中文,也可以是\F硬编码

    显示在textBrowser->setText 中文乱码 转成QObject::trUtf8即可. ui->textBrowser->setText((QObject::trUtf8 ...

  9. GIS基础软件及操作(八)

    原文 GIS基础软件及操作(八) 练习八.地理建模 地理建模:Model Builder 土壤侵蚀危险性建模分析 认识ModelBuilder操作界面 1: 添加硬盘上的数据或工具到模型中,数据也可以 ...

  10. SignalR的简单使用(二)

    原文:SignalR的简单使用(二) 之前提到SignalR代理在网页,通过生成的Js来完成相关的功能.但我不禁想一个问题, 难到SignalR的服务端就能寄存在web端吗,通过访问网页能方式才能启动 ...