编译原理基础课件.pptxVIP

编译原理基础课件.pptx

此“教育”领域文档为创作者个人分享资料,不作为权威性指导和指引,仅供参考
  1. 1、本文档共722页,可阅读全部内容。
  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.1 词法分析中的若干问题; (2) 标识符:标识符是程序设计语言中最大的一个类别,它的作用是为某个实体起一个名字,以便于今后称呼(引用),如draw_line、 sort等。可以用标识符来命名的实体包括类型、变量、过程、常量、类、对象、程序包、标号等,即类型名、变量名、过程名、常量名等。; (3) 字面量:字面量是指直接以其字面所表示的常量,如25、true、This is a string等。值得注意的是,字面量与常量是两个不同的概念,常量可以是一个字面量(直接表示),也可以是一个常量名(命名表示)。例如可以在Pascal中声明:const max_length = 25,显然25是一个常量,max_length也是一个常量,我们称25为字面量,而不称max_length为字面量。根据字面量的内容,可以将它们再进行更细的划分,如常数字面量(包括整型字面量、实型字面量、枚举字面量等)、字符串字面量等。; (4) 特殊符号:程序设计语言中的特殊符号,类似于自然语言中的标点符号,每个符号在程序设计语言中均有特殊用途。可以根据它们的用途,再细分为算符(如+、、*、/等)、分隔符(如;、”、“等)。 显然,一个单词究竟是标识符、关键字,还是特殊符号,需要根据一定的构词规则来产生和识别。我们将产生和识别单词的规则称为模式(patten),按照某个模式(规则)识别出的元素称为记号(token),而单词(lexeme)一词是指被识别出元素自身的值。; 例2.1 对于语句:position := initial + rate * 60,可以识别出下述序列: 标识符 特殊符号 标识符 特殊符号 标识符 特殊符号 数字字面量 其中position、initial、rate均被识别为标识符,因为它们均符合同一条规则,即以字母打头的字母数字串。记号至少含有两个信息:一个是记号的类别,如“标识符”;另一个是记号的值,如“position”。显然,如果把记号看作是一个类型的话,则单词就是一个类型中的实例。由于我们总是说识别出一个标识符,而不说识别出一个position或rate,因而将词法分析器识别出的序列称为记号流。 ; 记号的类别、模式以及单词三者之间的关系可以用表2.1加以说明。其中,const和if分别是被细分的关键字,它??的特点是一个记号类别仅对应一个单词;relation表示关系运算符;id表示标识符;num表示数字字面量;literal表示字符串字面量;comment表示注释,它们的特点是一个记号类别可以对应若干个单词。由于语法分析及其后的阶段并不对注释进行分析,因而可在词法分析阶段中滤掉注释,即词法分析器可以不向语法分析器返回comment。而其他的记号,均是源程序中的有效成分,需要返回给语法分析器。 ;表2.1 记号、模式与单词;2.1.2 记号的属性 从例2.1中已经知道,记号至少包含两个部分:记号类别和记号的其他信息。可以看出,记号的类别唯一标识一类记号,例如所有的关系运算符均可以由relation来标识,而所有字符串字面量均可以由literal来标识。所以,记号的类别可以被认为是记号的名字或记号的代表,在不引起混淆的情况下,将记号的类别简称为记号。记号的其他信息被称为记号的属性。例如,num可以取值3.1416,则称3.1416是num的属性,而literal可以取值“core dumped”(不含引号),则称“core dumped”是literal的属性。由此可见,记号的类别标识一类记号,而记号的类别加属性标识一个记号实例。; 在计算机内部,可以有不同的方式来表示记号的类别和属性。一般情况下,记号的类别可以用整型编码或枚举类型表示,如表2.1中每个记号类别可以用括号中的整型编码表示,如01表示const,82表示id等。根据记号类别的不同,记号的属性的值可以有不同的表示方法。relation的属性值是一个有限可枚举集合,可以用每个属性值在集合中的位置来表示它,如1表示,2表示=,依此类推。id的属性值是一个无限可枚举集合,因此,只能用每个标识符的原始输入形式(字符串)来表示,如pi、draw_line等。字面量的属性根据情况,其表示方式也不同,如数字字面量可由转义后的实际值表示,如表示为3.1416而不是“3.1416”,而字符串字面量就无需转义。; 例2.2 表达式mycount 25由表2.2的三个记号组成。其中标识符的属性值也可以由mycount在符号表中的入口(下标)来表示。;2.1.3 词法分析器的作用与工

文档评论(0)

子不语 + 关注
官方认证
服务提供商

平安喜乐网络服务,专业制作各类课件,总结,范文等文档,在能力范围内尽量做到有求必应,感谢

认证主体菏泽喜乐网络科技有限公司
IP属地山东
统一社会信用代码/组织机构代码
91371726MA7HJ4DL48

1亿VIP精品文档

相关文档