for循环语句的翻译程序设计(递归下降法、输出四元式表示)

for循环语句的翻译程序设计(递归下降法、输出四元式表示)

ID:8802854

大小:381.50 KB

页数:19页

时间:2018-04-08

for循环语句的翻译程序设计(递归下降法、输出四元式表示)_第1页
for循环语句的翻译程序设计(递归下降法、输出四元式表示)_第2页
for循环语句的翻译程序设计(递归下降法、输出四元式表示)_第3页
for循环语句的翻译程序设计(递归下降法、输出四元式表示)_第4页
for循环语句的翻译程序设计(递归下降法、输出四元式表示)_第5页
资源描述:

《for循环语句的翻译程序设计(递归下降法、输出四元式表示)》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、武汉理工大学《编译原理》课程设计说明书1、系统描述21.1、实验思想21.2、设计内容21.3、翻译过程21.3.1、词法分析:21.3.2、语法分析:31.3.3、中间代码生成:41.3.4、属性文法:42、递归下降法42.1、递归下降法的主要思想:42.2、用程序表示递归子程序的内部结构:42.3、递归下降法对文法的限制:53、语法制导翻译53.1、翻译任务的处理过程53.2、语法制导翻译:53.3、基于属性文法的处理方法64、中间代码形式的描述及中间代码序列的结构设计65、简要的分析与概要设计65.1、词法分析:65.2源代码85.3运行结果156、测试

2、方法和测试结果166.1测试过程166.2测试结论187、课程设计总结188、参考文献20-19-武汉理工大学《编译原理》课程设计说明书1、系统描述1.1、实验思想通过设计、编制、调试一个FOR循环语句的语法及语义分析程序,加深对语法及语义分析原理的理解,实现词法分析程序对单词序列的词法检查和分析,并且实现对单词序列的语法分析、语义分析以及中间代码生成。1.2、设计内容本设计按照要求设计出for语句的简单文法,并使用递归下降分析法对用户输入的程序进行分析和翻译。对下列正确的程序输入:fori=1step1until10dok=j#结果程序要对该输入进行词法分析

3、,然后利用递归下降的分析法对词法分析得到的单词序列进行语法分析,经过语法制导翻译显示出等价的三地址表示的中间代码。对于错误的程序输入,如:Fori=1step1until10k=j#结果程序要指出程序出错。1.3、翻译过程1.3.1、词法分析:词法分析是计算机科学中将字符序列转换为单词(Token)序列的过程。进行语法分析的程序或者函数叫作词法分析器(Lexicalanalyzer,简称Lexer),也叫扫描器(Scanner)。词法分析器一般以函数的形式存在,供语法分析器调用。词法分析是编译过程中的第一个阶段,在语法分析前进行。也可以和语法分析结合在一起作为

4、一遍,由语法分析程序调用词法分析程序来获得当前单词供语法分析使用。简化设计、改进编译效率、增加编译系统的可移植性。词法分析是编制一个读单词的过程,从输入的源程序中,识别出各个具有独立意义的单词,即基本保留字、标识符、常数、运算符、分隔符五大类。并依次输出各个单词的内部编码及单词符号自身值。单词的分类主要分为五类:1.关键字:由程序语言定义的具有固定意义的标识符。也称为保留字或基本字。-19-武汉理工大学《编译原理》课程设计说明书2.标识符:用来表示程序中各种名字的字符串。3.常数:常数的类型一般有整型、实型、布尔型、文字型。4.运算符:如+、-、*、/等。5.

5、界限符:如逗号、分号、括号等。词法分析器输出的单词符号常表示成如下的二元式:(单词种别,单词符号的属性值)1.3.2、语法分析:语法分析是编译过程的一个逻辑阶段。语法分析的任务是在的基础上将单词序列组合成各类语法短语,如“程序”,“语句”,“表达式”等等.语法分析程序判断源程序在结构上是否正确.源程序的结构由上下文无关文法描述.语法分析程序可以用YACC等工具自动生成。语法分析是编译程序的核心部分,其主要任务是确定语法结构,检查语法错误,报告错误的性质和位置,并进行适当的纠错工作。语法分析的主要工作:是识别由词法分析给出的单词序列是否是给定的正确句子(程序)。

6、语法分析常用的方法:自顶向下的语法分析和自底向上的语法分析两大类。此次设计中语法分析中主要通过递归下降分析法对语法分析处理过程进行控制,使输出的三地址表示的翻译的工作有条不紊的进行,同时识别语法分析中的语法错误。递归下降法主要采用自顶向下方法,即从文法的开始符号开始进行分析,逐渐推导的往下构造语法树,使其树叶正好构造出所给定的源程序串。自顶向下方法的关键是确定在推导过程中选择候选式的问题。当进行推导时,一个非终结符可能对应多个产生式,这样我们就无法事先知道应该用哪个产生式,因此实用都作了一些限制。以便在任何情况下都能确定应该用的产生式。自顶向下的主要思想是从开

7、始符出发导出句型并一个符号一个符号地与给定终结符串进行匹配。如果全部匹配成功,则表示开始符号可推导出给定的终结符串。因此判定给定终结符号串是正确句子。词法分析程序和语法分析程序的关系:-19-武汉理工大学《编译原理》课程设计说明书1.3.3、中间代码生成:中间代码,也称中间语言,是复杂性介于源程序语言和机器语言的一种表示形式。为了使编译程序有较高的目标程序质量,或要求从编译程序逻辑结构上把与机器无关和与机器有关的工作明显的分开来时,许多编译程序都采用了某种复杂性介于源程序语言和机器语言之间的中间语言。中间代码(语言)是一种特殊结构的语言,编译程序所使用的中间代

8、码有多种形式。按其结构分常见的有逆波兰

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。