博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
设计模式之解释器模式(行为型)
阅读量:4347 次
发布时间:2019-06-07

本文共 1513 字,大约阅读时间需要 5 分钟。

目录

一、模式定义

解释器模式(Interpreter Pattern):定义语言的文法,并且建立一个解释器来解释改语言中的句子,这里的“语言”意思是规定格式和语法的代码,所以解释器模式是一种类行为型模式

二、模式角色

  • Context: 环境类
  • Client: 客户类
  • AbstractExpression: 抽象表达式
  • TerminalExpression: 终结符表达式
  • NonterminalExpression: 非终结符表达式

三、模式分析

模式表示,可以使用文法规则或抽象语法树来表示语言

文法规则实例:

  • expression ::= value | symbol
  • symbol ::= expression '+' expression | expression '-' expression
  • value ::= an integer //一个整数值

在文法规则定义中可以使用一些符号来表示不同的含义,如使用“|”表示或,使用“{”和“}”表示组合,使用“*”表示出现0次或多次等,其中使用频率最高的符号是表示或关系的“|” 。

除了使用文法规则来定义一个语言,在解释器模式中还可以通过一种称之为抽象语法树(Abstract Syntax Tree, AST)的图形方式来直观地表示语言的构成,每一棵抽象语法树对应一个语言实例。

在这里插入图片描述

四、典型例子

典型的解释器模式例子:

抽象表达式类:

public abstract class AbstractExpression{    public abstract void interpret(Context ctx);}

终结符表达式类:

public class TerminalExpression extends AbstractExpression{    public void interpret(Context ctx)    {        //对于终结符表达式的解释操作    }}

非终结符表达式类:

public class NonterminalExpression extends AbstractExpression{    private AbstractExpression left;    private AbstractExpression right;        public NonterminalExpression(AbstractExpression left,AbstractExpression right)    {        this.left=left;        this.right=right;    }        public void interpret(Context ctx)    {        //递归调用每一个组成部分的interpret()方法        //在递归调用时指定组成部分的连接方式,即非终结符的功能    }   }

环境类代码:

public class Context{    private HashMap map = new HashMap();    public void assign(String key, String value)    {        //往环境类中设值    }public String lookup(String key)    {        //获取存储在环境类中的值    }}

例子来自一书

转载于:https://www.cnblogs.com/mzq123/p/10703067.html

你可能感兴趣的文章
Codeforces 1141E Superhero Battle
查看>>
多态特性
查看>>
团队冲刺绩效计算方法及排名
查看>>
【树莓派】h2数据库操作相关
查看>>
让Android手机变得无所不能-几种很有创意的Android外设展示
查看>>
给第三方dll加上强命名的方法[C#]
查看>>
Maximum Subarray
查看>>
Java学习笔记XML(3)
查看>>
java学习笔记—Tomcat(9)
查看>>
错排问题 (Mathematics)
查看>>
Uml学习-用例建模简介
查看>>
石子合并问题(一) (基础的区间dp)
查看>>
让你的JS更优雅的小技巧
查看>>
报错:the input device is not a TTY
查看>>
小菜鸟第一次面试总结!长姿势了!(一)
查看>>
javascript 第27节 jQuery选择器
查看>>
Amazon S3云存储服务器的功能及编程接口
查看>>
json学习系列(8)JSON与JAVA数据的相互转换实例
查看>>
初步了解会计学
查看>>
java MD5加密
查看>>