当前字符词法分析结果缓冲区计数器存放识别的字行字符缓冲区最多个字符字符缓冲区指针变量名表共项,每项长度为真值假值在布尔表达式中保存有关布尔变量的真假值指向的指针匹配表的结构,用来与输入缓冲区中的单词进行匹配,匹配表初始化,大小为存放名字存放名字所对应的值,词法分析结果缓冲区,读取二元式的当前字符,当前表达式中的字符,非终结符,算术或布尔表达式加工处理使用的符号栈,算术或布尔表达式使用的缓冲区语法分析加工处理使用的符号栈四元式中空白位置四元式的结构定义指向栈指针指向词法分析缓冲区的指针词法分析中记录单词的长度变量名表指针源程序文件,为结束符源程序行数记数为赋值语句为语句为语句临时变量计数器总是指向下个将要形成的四元式地址,每次执行时,地址自动增扫描分析表过程中保存的当前状态值扫描分析表或表所保存的当前状态值查找分析表时状态栈的栈顶指针状态栈定义状态栈的栈顶指针算术或布尔表达式缓冲区指针记录下条四元式的地址真值链假值链记录语句嵌套层次的数组,即记录嵌套中每层的布尔表达式的首地址记录语句嵌套层次的数组,即记录每层之前的四元式地址数组指针数组指针五编译程序运行测试测试得源程序如下经编译程序运行后得到的输出结果如下词法分析得出的相应的名字的号码和他的值列举程序中所有的变量状态栈的移进归约过程最后产生的四元式中间代码布尔表达式的分析表设计如下过程略,,分析表控制语义加工的实现当扫描分析表的当前状态为归约状态时,则在调用与该状态对应的产生式进行归约的同时,调用相应的语义子程序进行有关的翻译工作。现在对分析器的分析栈加以扩充,使得每个文法符号之后都跟着它的语义值。为了清晰起见,我们把这个栈的每项看成由三部分组成状态,文法符号和语义值。编译程序实现算术表达式布尔表达式及程序语句的语义加工时,都是按这种状态栈加工方式进行的。例如的分析过程序号真的代码假出口的四元式串。的真出口只有在往回扫描到时才能知道,而它图条件语句的代码结构的假出口则需到处理过并且到达才能明确。这就是说,必须把的值传下去,以便到达相应的时才进行回填。另外,当语句执行完时意味着整个语句也已执行完毕因此,在的编码之后应产生条无条件转移指令。这条转移指令将导致程序控制离开整个语句。但是,在完成的翻译之前,这条无条件转移指令的转移目标是不知道的。甚至,在翻译完之后,这条转移指令的转移目标仍无法确定。这种情形是由于语句的嵌套性所引起的。例如下面的语句在的代码之后的那条无条件转移指令不仅应跨越而且应跨越。这也就是说,转移目标的确定和语句所处的环境密切相关。条件循环语句条件循环语句通常被翻译成图的代码结构。布尔式的真出口出向代码段的第个四元式。紧接代码段之后应产生条转向测试的无条件转移指令。的假出口将导致程序控制离开整个语句。的假出口目标即使在整个语句翻译完之后也未必明确。例如这种情况仍是由于语句的嵌套性引起的。所以,我们只好把它作为语句的语义值暂留下来,以便在处理外层语句时再伺机回填。语法翻译实现方法将上述语法翻译付诸实现过程中,我们仅保留了算术表达式和布尔表达式翻译的文法和语义动作面对程序语句的翻译,由于改造后含有较多的非终结符且语义动作又相对简单,故仍恢复为改造之前的程序语句文法。由于总体上构造个分析表来实现语法分析及语义加工将使得所构造的分析表过大,所以将其分为下面三部分处理对算术表达式单独处理,即为算术表达式构造个分析表,并将赋值语句与算术表达式归为类处理,处理之后的赋值语句仅看作为程序语句文法中的个终结符。对布尔表达式也单独处理,并为其构造个分析表,经分析表处理后的布尔表达式看作为程序语句文法中的个终结符。程序语句文法此时变为此时为程序语句构造相应的分析表就简单多了。前面的程序语句文法中所添加的非终结符是为了能及时回填有关四元式转移目标而引入的,在取消了这些非终结符后又如何解决及时回填转移目标的问题呢我们采取的解决方法是增加两个数组和来分别记录语句嵌套中每层布尔表达式如果有的话的首地址以及每层如果有的话之前的四元式地址即无条件转出此层语句的四元式。也即,对程序语句的翻译来说在处理完布尔表达式后,回填或语句的真值链在归约完每个语句之后检查符号栈,看在之前的文法符号是否或,若是则回填假值链假值入口为语句所对应的四元式序列之后对语句,此时已在该序列之在分析过程中,第步操作后的状态栈为,根据栈顶状态和现行输入符号栏字符串的第个字符查分析表即按第个产生式来进行归约由于产生式右部仅含项,故去掉状态栈栈顶此时变为新的栈顶状态,再查,的下状态即将状态和文法符号压栈,最后得到第步的状态。第步操作后也是如此,当前状态栈为,根据栈顶状态和现行输入符号查分析表即按第个产生式进行归约由于产生式右部有三项,故去掉状态栈栈顶的三项此时变为新的栈顶状态,再查,的下状态即将状态和文法符号压栈,最后得到第步的状态。三中间代码生成器设计布尔表达式布尔表达式在程序语言中有两个基本作用是用作控制语句如或
温馨提示:手指轻点页面,可唤醒全屏阅读模式,左右滑动可以翻页。
第 1 页 / 共 14 页
第 2 页 / 共 14 页
第 3 页 / 共 14 页
第 4 页 / 共 14 页
第 5 页 / 共 14 页
第 6 页 / 共 14 页
第 7 页 / 共 14 页
第 8 页 / 共 14 页
第 9 页 / 共 14 页
第 10 页 / 共 14 页
第 11 页 / 共 14 页
第 12 页 / 共 14 页
第 13 页 / 共 14 页
第 14 页 / 共 14 页
预览结束,喜欢就下载吧!
1、手机端页面文档仅支持阅读 15 页,超过 15 页的文档需使用电脑才能全文阅读。
2、下载的内容跟在线预览是一致的,下载后除PDF外均可任意编辑、修改。
3、所有文档均不包含其他附件,文中所提的附件、附录,在线看不到的下载也不会有。
1、该文档不包含其他附件(如表格、图纸),本站只保证下载后内容跟在线阅读一样,不确保内容完整性,请务必认真阅读。
2、有的文档阅读时显示本站(www.woc88.com)水印的,下载后是没有本站水印的(仅在线阅读显示),请放心下载。
3、除PDF格式下载后需转换成word才能编辑,其他下载后均可以随意编辑、修改、打印。
4、有的标题标有”最新”、多篇,实质内容并不相符,下载内容以在线阅读为准,请认真阅读全文再下载。
5、该文档为会员上传,下载所得收益全部归上传者所有,若您对文档版权有异议,可联系客服认领,既往收入全部归您。