- 1、本文档共25页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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等集合类充当环境类),
您可能关注的文档
- 6、树与二叉树.ppt
- 6、找骆驼.ppt
- 6、魏晋南北朝散文辞赋.ppt
- 6、查验预防接种证.ppt
- 68讲:英汉互译实践与技巧.ppt
- 6功与能.ppt
- 6发电机电枢反应.ppt
- 6变异度指标.ppt
- 6平人气象论.ppt
- 6常见攻击方法(二).ppt
- 2024高考物理一轮复习规范演练7共点力的平衡含解析新人教版.doc
- 高中语文第5课苏轼词两首学案3新人教版必修4.doc
- 2024_2025学年高中英语课时分层作业9Unit3LifeinthefutureSectionⅢⅣ含解析新人教版必修5.doc
- 2024_2025学年新教材高中英语模块素养检测含解析译林版必修第一册.doc
- 2024_2025学年新教材高中英语单元综合检测5含解析外研版选择性必修第一册.doc
- 2024高考政治一轮复习第1单元生活与消费第三课多彩的消费练习含解析新人教版必修1.doc
- 2024_2025学年新教材高中英语WELCOMEUNITSectionⅡReadingandThi.doc
- 2024_2025学年高中历史专题九当今世界政治格局的多极化趋势测评含解析人民版必修1.docx
- 2024高考生物一轮复习第9单元生物与环境第29讲生态系统的结构和功能教案.docx
- 2024_2025学年新教材高中英语UNIT5LANGUAGESAROUNDTHEWORLDSect.doc
文档评论(0)