适配器模式之解释器模式

设计模式目录
http://blog.csdn.net/fenglailea/article/details/52733435
风.fox

解释器模式 Interpreter Pattern

给定一门语言,定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中的句子

通用类图

组成

  • 抽象解释器 AbstractExpression
    具体的解释任务由各个实现类完成,具体的解释器分别由TerminalExpression和NonterminalExpression完成。
  • 终结符表达式 TerminalExpression
    实现与文法中的元素相关联的解释操作,通常一个解释器模式中只有一个终结符表达式,但有多个实例,对应不同的终结符。具体到我们例子就是VarExpression类,表达式中的每个终结符都在堆栈中产生了一个VarExpression对象。
  • 非终结符表达式 NonterminalExpression
    文法中的每条规则对应于一个非终结表达式,具体到我们的例子就是加减法规则分别对应到AddExpression和SubExpression两个类。非终结符表达式根据逻辑的复杂程度而增加,原则上每个文法规则都对应一个非终结符表达式。
  • 环境角色 Context

通用源码

JAVA

//抽象表达式
public abstract class Expression {
    //每个表达式必须有一个解析任务
    public abstract Object interpreter(Context ctx);
}
//终结符表达式
public class TerminalExpression extends Expression[
    //通常终结符表达式只有一个,但是有多个对象
    public Object interpreter(Context ctx){
        return null;
    }
}
//非终结符表达式
public class NonterminalExpression extends Expression[
    //每个终结符表达式都会对其他表达式产生依赖
    public NonterminalExpression(Expression... expression){
    }
    public Object interpreter(Context ctx){
        //进行文法处理
        return null;
    }
}
//场景
public class Client{
    public static void main(String[] arg){
        Context ctx = new Context();
        //通常定义一个语法容器,容纳一个具体的表达式,通常为ListArray,LinkedList,Stack等等
        Stack&Expression>stack =null;
        for(;;){
            .....
        }
        //产生一个完整的语法树,由各个具体的语法分析进行解析
        Expression exp=stack.pop();
        //具体元素进入场景
        exp.interpreter(ctx);
    }
}

使用场景

重复发生的问题
一个简单语法需要解释的场景

时间: 2025-01-31 07:06:40

适配器模式之解释器模式的相关文章

PHP设计模式之解释器模式

解释器: 解释器设计模式用于分析一个实体的关键元素,并且针对每个元素都提供自己的解释或相应的动作. 解释器设计模式最常用于PHP/HTML 模板系统. <?php        class User {            protected $_username = "";            public function __construct($username) {                $this->_username = $username;  

.Net设计模式实例之解释器模式(Interpreter Pattern)

一.解释器模式简介(Brief Introduction) 解释器模式(Interpreter Pattern),给定一个语言,定义它的文法的一种表示,并定 义一个解释器,这个解释器使用该表示来解释语言中的句子.使用了解释器模式,可以很容 易地改变和扩展文法,因为该模式使用类来表示文法规则,可以使用继承来改变或扩展该文 法.也比较容易实现文法,因为定义抽象语法树中各个节点的类的实现大体类似,这些类容 易直接编写. 二.解决的问题(What To Solve) 如果一种特定类型的问题发生的频率足够

Java设计模式编程之解释器模式的简单讲解_java

0.解释器(Interpreter)模式定义 :给定一门语言,定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中句子. 属于行为型模式. 解释器模式在实际的系统开发中使用的非常少,因为它会引起效率.性能以及维护等问题. 解释器模式的通用类图如图所示. 1.解释器模式的优点 解释器是一个简单语法分析工具,它最显著的优点就是扩展性,修改语法规则只要修改相应的非终结符表达式就可以了,若扩展语法,则只要增加非终结符类就可以了. 2.解释器模式的缺点 解释器模式会引起类膨胀:每个语法

20、Python与设计模式--解释器模式

一.模拟吉他 要开发一个自动识别谱子的吉他模拟器,达到录入谱即可按照谱发声的效果.除了发声设备外(假设已完成),最重要的就是读谱和译谱能力了.分析其需求,整个过程大致上分可以分为两部分:根据规则翻译谱的内容:根据翻译的内容演奏.我们用一个解释器模型来完成这个功能. class PlayContext(): play_text = None class Expression(): def interpret(self, context): if len(context.play_text) ==

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

原文:乐在其中设计模式(C#) - 解释器模式(Interpreter Pattern)[索引页][源码下载] 乐在其中设计模式(C#) - 解释器模式(Interpreter Pattern) 作者:webabcd 介绍 给定一个语言, 定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中的句子. 示例 有一个Message实体类,某个类对它的操作有Get()方法.现在要求用具有某一规则的中文语法来执行这个操作. MessageModel using System;usin

第19章 解释器模式(Interpreter Pattern)

原文 第19章 解释器模式(Interpreter Pattern) 解释器模式        导读:解释器模式,平常用的比较的少,所以在写这个模式之前在博客园搜索了一番,看完之后那叫一个头大.篇幅很长,我鼓足了劲看了半天的描述跟解释,可能是本人的水平有限,或者是耐心太差,看到一半就有点扛不住了.我感觉对于一个菜鸟或者是没接触过设计模式的人来说,在看设计模式的时候更希望作者能简短的用几行代码来描述设计模式,这样起码看完大体有个概念.           概述:          Interpre

Java设计模式(二十三)----解释器模式

解释器模式 定义:解释器模式是类的行为模式.给定一个语言之后,解释器模式可以定义出其文法的一种表示,并同时提供一个解释器.客户端可以使用这个解释器来解释这个语言中的句子. 解释器模式的结构 下面就以一个示意性的系统为例,讨论解释器模式的结构.系统的结构图如下所示: 模式所涉及的角色如下所示: (1)抽象表达式(Expression)角色:声明一个所有的具体表达式角色都需要实现的抽象接口.这个接口主要是一个interpret()方法,称做解释操作. (2)终结符表达式(Terminal Expre

解析Java的设计模式编程之解释器模式的运用_java

定义:给定一种语言,定义他的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中句子.类型:行为类模式类图: 解释器模式是一个比较少用的模式,本人之前也没有用过这个模式.下面我们就来一起看一下解释器模式.  解释器模式的结构抽象解释器:声明一个所有具体表达式都要实现的抽象接口(或者抽象类),接口中主要是一个interpret()方法,称为解释操作.具体解释任务由它的各个实现类来完成,具体的解释器分别由终结符解释器TerminalExpression和非终结符解释器Nontermina

JAVA设计模式之解释器模式详解_java

在阎宏博士的<JAVA与模式>一书中开头是这样描述解释器(Interpreter)模式的: 解释器模式是类的行为模式.给定一个语言之后,解释器模式可以定义出其文法的一种表示,并同时提供一个解释器.客户端可以使用这个解释器来解释这个语言中的句子. 解释器模式的结构 下面就以一个示意性的系统为例,讨论解释器模式的结构.系统的结构图如下所示: 模式所涉及的角色如下所示: (1)抽象表达式(Expression)角色:声明一个所有的具体表达式角色都需要实现的抽象接口.这个接口主要是一个interpre