8 C设计模式解释器模式.pptVIP

  1. 1、本文档共25页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
8C设计模式解释器模式ppt课件

www.ChinaSA.info www.ChinaSA.info Design Patterns 解释器模式 刘 伟 (Sunny) weiliu_china@126.com 大纲 解释器模式概述 文法规则和抽象语法树 解释器模式的结构与实现 解释器模式的应用实例 解释器模式的优缺点与适用环境 要不要弄个新的编程语言玩玩? 解释器模式概述 加法/减法解释器示意图 解释器模式概述 分析 C#语言无法直接解释类似“1 + 2 + 3 – 4 + 1”这样的字符串 定义一套文法规则来实现对这些语句的解释,即设计一个自定义语言 基于现有的编程语言 ? 面向对象编程语言 ? 解释器模式 解释器模式概述 解释器模式的定义 类行为型模式 解释器模式:给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。 Interpreter Pattern: Given a language, define a representation for its grammar along with an interpreter that uses the representation to interpret sentences in the language. 解释器模式概述 解释器模式的定义 在解释器模式的定义中所指的“语言”是使用规定格式和语法的代码 是一种使用频率相对较低但学习难度相对较大的设计模式,用于描述如何使用面向对象语言构成一个简单的语言解释器 能够加深对面向对象思想的理解,并且理解编程语言中文法规则的解释过程 文法规则和抽象语法树 文法规则 1 + 2 + 3 – 4 + 1 “::=”表示“定义为” “|”表示“或” “{”和“}”表示“组合” “*”表示“出现0次或多次” expression ::= value | operation operation ::= expression + expression | expression - expression value ::= an integer //一个整数值 文法规则和抽象语法树 抽象语法树 抽象语法树(Abstract Syntax Tree, AST) 描述了如何构成一个复杂的句子,通过对抽象语法树的分析,可以识别出语言中的终结符类和非终结符类 非终结符表达式 终结符表达式 解释器模式的结构与实现 解释器模式的结构 解释器模式的结构与实现 解释器模式的结构 解释器模式包含以下4个角色: AbstractExpression(抽象表达式) TerminalExpression(终结符表达式) NonterminalExpression(非终结符表达式) Context(环境类) 解释器模式的结构与实现 解释器模式的实现 典型的抽象表达式类代码: abstract class AbstractExpression { public abstract void Interpret(Context ctx); } 解释器模式的结构与实现 解释器模式的实现 典型的终结符表达式类代码: class TerminalExpression : AbstractExpression { public override void Interpret(Context ctx) { //终结符表达式的解释操作 } } 解释器模式的结构与实现 解释器模式的实现 典型的非终结符表达式类代码: class NonterminalExpression : AbstractExpression { private AbstractExpression left; private AbstractExpression right; public NonterminalExpression(AbstractExpression left, AbstractExpression right) { this.left = left; this.right = right; } public override void Interpret(Context ctx) { //递归调用每一个组成部分的interpret()方法 //在递归调用时指定组成部分的连接方式,即非终结符的功能 } } 解释器模式的结构与实现 解释器模式的实现 环境类Context: 用于存储一些全局信息,一般包含一个Hashtable或List等类型的集合对象(也可以直接由Hashtable等集合类充当环境类),

文档评论(0)

118books + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档