- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
语言与语言的翻译编译器的基本组成编译器的分析-综合模式.ppt
第一章内容回顾 语言与语言的翻译 编译器的基本组成 编译器的分析/综合模式(编译器基础架构) 扫描遍数 编译器的编写 第二章 词法分析——简介 词法分析器的作用与工作方式 词法分析器是编译器中唯一与源程序打交道的部分。 滤掉源程序中的无用成分,如注释、空格、回车等; 处理与平台有关的输入,如文件结束符的不同表示等; 识别记号,并交给语法分析器; 调用符号表管理器或出错处理器,进行相关处理 。 工作方式: (1)单独扫描,(2)作为语法分析器的子程序,(3)并行工作 第二章 词法分析——简介 两个概念: 词法规则(构词规则):规定单词形成的规则 相当于立法,规定语言所允许的合法单词 词法分析:根据词法规则识别输入序列 相当于执法,识别出合法的单词、指出非法的输入序列 主要内容 词法分析中的若干问题 模式的形式化描述 记号的识别 从正规式到词法分析器 单词(组成程序的元素) 第二章 词法分析——单词 单词的基本分类: 关键字(保留字), kw (key word, or reserved word) 在程序设计语言中有着固定的意义 while, if, else, for, class 不允许用它们再表示其它的意思 标识符 id (identifier) 程序设计语言中最大的一个类别 为实体起个名字,便于之后的称呼和使用 可以用标识符命名的实体包括:类型名、变量名、过程名、常量名、类名、对象名、程序包名等 字面量 literal,num 直接以其字面所表示的常量 25,true,“This is an apple” 注意:字面量和常量的区别(常量可以是字面量,也可以是常量名,pi) 特殊符号 ks (key symbol, or special symbol) 类似于自然语言中的标点符号,每个符号都有各自的特殊用途 +,-,*等 第二章 词法分析——单词 [例2.1]语句 position := initial + rate * 60 记号 id ks id ks id ks number 问题:一个单词究竟是标识符、关键字、字面量还是特殊符号? 根据构词规则来产生和识别 将产生和识别单词的规则称为模式,按照某个模式识别出的元素称为记号(token),而单词指被识别出元素自身的值。 第二章 词法分析——单词 三个术语: 模式(pattern):产生和识别元素的规则 记号(token): 按照某个模式(或规则)识别出的元素(一组) (记号的类别可以用整型编码表示,例01表示const) 单词(lexeme):被识别出的元素自身的值(一个),也称为词值 第二章 词法分析——记号 记号 记号是按照某个模式识别出的元素。 赋值句position := initial + rate * 60 position、initial和rate均为标识符,种类均是id。 问题:当识别出一个id时,如何判定是哪个id ? 当识别出一个relation时,究竟是 = 还是 ? 记号=记号的类别+记号的属性 [例2.2]表达式 mycount 25 由三个记号组成 类别 82 81 83 属性 “mycount” 5 25 注意:5? 第二章 词法分析——模式 编译原理课所涉及到的第一个形式化的概念 正则表达式涉及到的概念有:字母表、字符串、语言,正则表达式 [例2.3]字母表∑={a, b, c} 字符串: ε, a, b, c, aa, ab, ac, ba, bb, bc,… ∑上所有字符串构成的语言L: L={ε, a, b, c, aa, ab, ac, ba, bb, bc, ...} ∑上所有字符串(模式非形式化的表达) 形式化的表达: ∑* (正则表达式) 正则表达式表达的语言L(∑*)= {ε, a, b, c, aa, ab, ac, ba, bb, bc, ...} 第二章 词法分析——正则表达式 字符串:字母表上的字符构成的串 相关术语 示例 长度:|S| |abc| = 3 ε |ε| = 0 连接:S1S2 abc def = abcdef 多次连接:Sn (abc)3 = abcabcabc S的前缀X abc的前缀有:ε,a,a
您可能关注的文档
最近下载
- 北师大版六年级上册数学《百分数的认识》(课件)(共17张PPT).pptx VIP
- 2025村委换届考试题及答案.docx VIP
- 2024《小红书运动户外行业白皮书》.docx
- 推荐浙江省土建安全技术资料台帐(十二本).doc VIP
- 肠套叠护理PPT课件讲解PPT课件.pptx VIP
- (沪教版2024)二年级数学上册新教材解读课件.pptx
- 小儿肛管排气.pptx VIP
- 新解读《GB_T 5271.9 - 2001信息技术 词汇 第9部分_数据通信》最新解读.docx VIP
- 新解读《GB_T 18492-2001信息技术 系统及软件完整性级别》最新解读.docx VIP
- PPT灌肠操作及并发症处理.pptx VIP
本人在医药行业摸爬滚打10年,做过实验室QC,仪器公司售后技术支持工程师,擅长解答实验室仪器问题,现为一家制药企业仪器管理。
文档评论(0)