解释器模式原理及其在JDK源码中的体现
设计模式系列总览
设计模式 | 飞机票 |
---|---|
三大工厂模式 | 登机入口 |
策略模式 | 登机入口 |
委派模式 | 登机入口 |
模板方法模式 | 登机入口 |
观察者模式 | 登机入口 |
单例模式 | 登机入口 |
原型模式 | 登机入口 |
代理模式 | 登机入口 |
装饰者模式 | 登机入口 |
适配器模式 | 登机入口 |
建造者模式 | 登机入口 |
责任链模式 | 登机入口 |
享元模式 | 登机入口 |
组合模式 | 登机入口 |
门面模式 | 登机入口 |
桥接模式 | 登机入口 |
中介者模式 | 登机入口 |
迭代器模式 | 登机入口 |
状态模式 | 登机入口 |
解释器模式 | 登机入口 |
备忘录模式 | 登机入口 |
命令模式 | 登机入口 |
访问者模式 | 登机入口 |
软件设计7大原则和设计模式总结 | 登机入口 |
前言
解释器模式从字面上来理解就是需要去解释某些内容的含义,而实际上这也正是解释器模式的作用。本文主要会介绍解释器模式的原理,并会结合一个简单的示例来加深我们对解释器模式的理解,解释器模式在我们的应用开发层已经有了很多轮子,所以我们也比较少再去重造轮子。
什么是解释器模式
解释器模式(Interpreter Pattern)是指给定一门语言,定义它的文法的一种表示(如:加减乘除表达式和正则表达式等),然后再定义一个解释器,该解释器用来解释我们的文法表示(表达式)。
解释器模式是一种按照规定的语法(文法)来进行解析的一种设计模式,属于行为型模式。
好了,装逼时刻又到了:Talk is cheap,Show you the code,先看一个非常简单的例子。
终结符表达式和非终结符表达式
在解释器模式中有终结符表达式和非终结符表达式这两个概念。
- 终结符表达式(Terminal Expression):实现文法中与终结符有关的解释操作。文法中每一个终结符都有一个具体的终结符表达式与之相对应。比如我们的R=M+N运算,M和N就是终结符,对应的解析M和N的解释器就是终结符表达式。
- 非终符结表达式(Nonterminal Expression):实现文法中与非终结符有关的解释操作。文法中的每一条规则都对应了一个非终结符表达式。非终结表达式一般是文法中的运算符或者关键字,如上面公示:R=M+N中的“+”号就是非终结符,解析“+”号的解释器就是一个非终结符表达式。
解释器模式示例
下面我们就以简单的加减法表达式类简单写一个示例:
1、首先建立一个顶层的表达式接口:
package com.zwx.design.pattern.interpreter;
public interface IExpression {
int interpret();
}
2、定义一个抽象的非终结表达式(比如加号和减号这种就属于非终结表达式):
package com.zwx.design.pattern.interpreter;
/**
* 非终结表达式-抽象表达式
*/
public abstract class AbstractNonTerminalExpression implements IExpression{