2章高级语言和其语法描述.pptVIP

  1. 1、本文档共30页,可阅读全部内容。
  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文档。上传文档
查看更多
2章高级语言和其语法描述

第二章 高级语言及其语法描述;2.3 程序语言的语法描述;符号串的运算:;符号串的前缀与后缀(头和尾):若有符号串 z=xy(x,y是符号串),我们称x为z的前缀,y为z的后缀。;符号串集合的运算:;符号串集合的幂运算:设A为符号串集合,则集合的幂运算定义如下:;设有字母表Σ={a…z, 0…9, type, var, const, if, then, else, for, to, do, case, begin, end,…, 各种运算符和其它特殊符号,…}, 则,由这些字母表中的元素(符号)可以组成不同的符号串: ;二、上下文无关文法 (p26);规则:规则又叫产生式(production rule),它是句子结构的另一种表示结构,它引入了符号“::=”或“→”表示“由……组成”,上述句子的结构可以表示如下:;句子的推导:用规则(产生式)按一定方式去推导或产生句子的过程。;三、文法和语言的形式定义;例 G1 =({N},{0,1},{N→0N,N→1N,N→0,N→1},N) ;定义3 符号串的推导与归约:已给文法G=(VN,VT,P,S), V= VN∪VT,令x,y,α,β∈V*,且α→β∈P,此时,由符号串xαy能够直接产生出符号串xβy,我们称:;引用巴科斯范式(BNF)表示文法:;定义4 句型和句子:设G=(VN,VT,P,S)是一文法;定义5 规范推导(归约):对于直接推导xαy? xβy,如果y只包含终结符号或为空符号串,那么就把这种直接推导称为规范(最右)推导,跟其对应的归约称为规范(最右)归约,且记作:;形式语言理论可以证明以下两点:;例2:已知语言为 L(G)={abna | n?1} 试给出其文法。;(2)递归文法: 若文法中至少存在一条递归产生式则称该文法是直接递归的文法; ;例:有文法G无符号整数 (1)无符号整数 →数字串 (2)数字串 →数字串数字 |数字 (3)数字 →0 |1 |2 |3 |4 |5 |6 |7 |8 |9|;定义8 短语、简单短语和句柄:设文法 G=(VN,VT,P,S) ,且 U?VN,x,y,u ?V*;(3)任一句型的最左简单短语称为该句型的句柄.;2.4文法的分类;2型文法: 产生式形式为 U →u 且 U?VN u?V*则称该文法为2型文法,也称为上下文无关文法。2型文法所确定的语言为2型语言,大部分程序设计语言都是2型语言。;2.5语法树和文法的二义性;子树:由语法树的某个结点(子树的根)连同它下面射出的部分组成语法树的子树。只含有单层分支的子树为简单子树。;文法的二义性:若一个文法存在某个句子对应两棵不同的语法树,则称此文法是二义性文法,运用文法描述程序设计语言的语句成份,一般希望所给文法是非二义文法,但是,有时候采用二义性文法比非二义文法要简单的多,所以,经常用二义性文法描述程序设计语言。 ;2.6 有关文法的实用限制;2.7 扩充的巴科斯范式(EBNF)表示;3. 使用圆括号()——提取候选式的公用因子

文档评论(0)

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

分享好文档!

1亿VIP精品文档

相关文档