编译原理试验手册

编译原理试验手册

ID:1482733

大小:328.50 KB

页数:34页

时间:2017-11-11

编译原理试验手册_第1页
编译原理试验手册_第2页
编译原理试验手册_第3页
编译原理试验手册_第4页
编译原理试验手册_第5页
资源描述:

《编译原理试验手册》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、编译原理实验手册编译原理实验手册第33页总32页编译原理实验手册实验介绍本实验面向的是本科阶段的编译原理课程设计,主要应用lex&yacc来实现我们自定义的一种Tiny语言的编译器。一、实验内容本学期的编译实验内容是实现一个简单的TINY语言的编译器。这个编译器的输入是TINY语言源代码,输出为自定义汇编语言。TINY语言汇编程序图1.1编译程序的功能TINY源程序编译程序整个编译器又分为词法分析、语法分析、语义分析、汇编代码生成四部分。其中大家编码实现这四部分。这四部分分别称之为PP1、PP2、PP3、PP4,如图1.2所示:图

2、1.2编译程序的流程汇编代码(PP4)词法分析(PP1)TINY源程序语义分析(PP3)语法分析(PP2)二、实验环境Windows操作系统,集成调试环境采用MicrosoftVisualC++。编程语言是Lex扫描程序生成器(Flex),Yacc分析生成器(Bison)。最后生成TINY语言的编译器。三、实验要求1.提交实验:请大家按照如下目录结构整理自己的程序和文档第33页总32页编译原理实验手册DocumentsSource[Extension][Test][Source]BaseDocuments目录中应当有一个设计文档r

3、eadme。在文档中请写明姓名、班号、学号、Email等个人信息,以便遇到问题时可以及时与你联系。此外,文档中还要写明程序实现的功能,主要数据结构的设计,重要算法的流程,以及实验中遇到的问题和解决方法。如果对实验做了扩展,在文档还要详细说明扩展实现的功能及实现方法。需要特别注意的是,如果在自己的实验程序中借用了别人的算法或代码,必须在文档中明确说明,并在源程序中加以注释,否则按照抄袭论处。Base目录中应当包含实现了基本要求的程序代码。其中的Source子目录中是程序代码,这个目录中应包括程序运行需要的所有文件(包括那些不需要你修

4、改的文件)。Test目录中应包括我们给出的所有测试文件及其标准输出。无论你是否对程序进行扩展,这个目录的内容都是必须要有的。Extension目录是可选的。如果你对程序进行了扩展,请将扩展版本的源代码和测试文件放在这个目录中。其中的Source子目录中是扩展后的程序代码。Test子目录中是你针对扩展部分提供的测试文件及相应的输出。此外,还请提供一个测试文档test,说明你的扩展能够处理的输入,以便助教在测试时设计相应的测试文件。最后,请将上述所有的程序文件打包成zip文件,zip文件名为“自己的学号.zip”,例如“981362.

5、zip”,并上载到服务器目录下或用邮件交上来。1.评分标准实验部分在总成绩中占20%。评分的主要标准是程序输出与标准输出相符合的程度。扩展部分在整个实验完成后酌情统一加分。2.检查方式在大家提交实验后,我们将对提交的程序进行测试。同时,在平时小测和期末考试中,会考察与实验相关的内容。对于那些实验题目回答得很差的同学,我们将下调其实验成绩。基本知识在开始我们的实验之前,我们要先介绍我们编译原理实验所用到的两个工具lex和yacc.第33页总32页编译原理实验手册基于这两个工具我们将完成我们的实验.Lex快速入门:Lex代表Lexic

6、alAnalyzar。Lex是一种生成扫描器的工具。扫描器是一种识别文本中的词汇模式的程序。这些词汇模式(或者常规表达式)在一种特殊的句子结构中定义,这个我们一会儿就要讨论。一种匹配的常规表达式可能会包含相关的动作。这一动作可能还包括返回一个标记。当Lex接收到文件或文本形式的输入时,它试图将文本与常规表达式进行匹配。它一次读入一个输入字符,直到找到一个匹配的模式。如果能够找到一个匹配的模式,Lex就执行相关的动作(可能包括返回一个标记)。另一方面,如果没有可以匹配的常规表达式,将会停止进一步的处理,Lex将显示一个错误消息。Le

7、x和C是强耦合的。一个.l文件(Lex文件具有.l的扩展名)通过lex公用程序来传递,并生成C的输出文件。这些文件被编译为词法分析器的可执行版本。Lex的常规表达式常规表达式是一种使用元语言的模式描述。表达式由符号组成。符号一般是字符和数字,但是Lex中还有一些具有特殊含义的其他标记。下面定义了Lex中使用的一些标记并给出了几个典型的例子。用Lex定义常规表达式字符含义A-Z,0-9,a-z构成了部分模式的字符和数字。.匹配任意字符,除了。-用来指定范围。例如:A-Z指从A到Z之间的所有字符。[]一个字符集合。匹配括号内的任意

8、字符。如果第一个字符是^那么它表示否定模式。例如:[abC]匹配a,b,和C中的任何一个。*匹配0个或者多个上述的模式。+匹配1个或者多个上述模式。?匹配0个或1个上述模式。$作为模式的最后一个字符匹配一行的结尾。{}指出一个模式可能出现的次数。例

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

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

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