- 1、本文档共39页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
* (2)符号栈 用于存放文法符号,栈顶为推导过程中句型尚未匹配部分的开头符号。 分析开始时,栈底先放一个#,然后放进文法开始符号,即 (3)预测分析总控程序 总是按栈顶符号x和当前输入符号行事。 对于任何(x,a),总控程序每次都执行下述三种可能动作之一: (a)若x=a=‘#’,则宣布分析成功。 (b)若x=a?‘#’,则把x从栈顶逐出,指针指向下一输入符号。 (c)若x是一个非终结符,则查看分析表M。 ①如果M[A, a]中存放关于X的一个产生式,那么,首先把X顶出栈,然后把产生式右部符号串按反序一一推进栈。 ②如果M[A, a]中存放“出错标志”,则调用出错处理程序ERROR。 综合例题 S # * 4.5 实例:PL/0编译程序的语法分析 PL/0编译程序语法分析方法是确定的自顶向下分析,采用的是递归子程序法。 PL/0编译程序总体流程图如下: 启动 置初值 调用GETSYM取单词 调用BLOCK过程 出错 当前单词是否为源程序结束符‘·’? 源程序中是否有错误? 打印错误 调用解释过程INTERPRET解释执行目标程序 结束 N Y N Y 从图中可看出, BLOCK过程是整个编译过程的核心, 它完成了语法分析和代码生成的任务。 * PL/0编译程序是用PASCAL语言书写的, 整个编译程序是由18个嵌套及并列的过程或函数组成, 如下表所示: 过程或函数名 简要功能说明 PL0 error getsym getch gen test block enter position(函数) constdeclaration vardeclaration listcode statement expression term factor condition interpret base(函数) 主程序 出错处理,打印出错位置和错误编码 词法分析,读取一个单词 滤掉空格,读取一个字符 生成目标代码,并送入目标程序区 测试当前单词符号是否合法 分程序分析处理过程 登录名字表 查找标识符在名字表中位置 常量定义处理 变量说明处理 列出目标代码清单 语句部分处理 表达式处理 项处理 因子处理 条件处理 对目标代码的解释执行程序 通过静态链求出数据区的基地址 PL/0编译程序的过程或函数的功能表 * plo error getsym getch gen test block enter position constdeclaration vardeclaration listcode statement expression term factor condition interpret base 这些过程或函数的嵌套定义层次结构如图: 各分析子程序之间的调用关系如下图: 分 程 序 语 句 条 件 表 达 式 工 页 因 子 * PL/0语法调用关系图。 程 序 注 解 PROCEDURE statement (fsys:symset); var i, xc1, cx2: integer; procedure expression (fsys:symset); var addop:symbol; procedure term (fsys:symset); var mulop:symbol; procedure factor (fsys:symset); var i:integer; begin while sym in facbegsys do begin if sym=ident then
您可能关注的文档
- 刘新昱《计算机信息技术教程》第2章2.6 外存储器.ppt
- 刘新昱《计算机信息技术教程》第2章2.7 常用医学信息采集与处理设备.ppt
- 刘新昱《计算机信息技术教程》第3章 复习重点.ppt
- 刘新昱《计算机信息技术教程》第3章3.1 软件概述.ppt
- 刘新昱《计算机信息技术教程》第3章3.2 操作系统.ppt
- 刘新昱《计算机信息技术教程》第3章3.3 算法和程序设计.ppt
- 刘新昱《计算机信息技术教程》第3章3.4 常用应用软件.ppt
- 刘新昱《计算机信息技术教程》第4章4.1 计算机网络基础.ppt
- 刘新昱《计算机信息技术教程》第4章4.2 计算机局域网.ppt
- 刘新昱《计算机信息技术教程》第4章4.3 计算机广域网.ppt
文档评论(0)