编译原理语法实验.doc

编译原理语法实验.doc

ID:57285751

大小:47.50 KB

页数:11页

时间:2020-08-09

编译原理语法实验.doc_第1页
编译原理语法实验.doc_第2页
编译原理语法实验.doc_第3页
编译原理语法实验.doc_第4页
编译原理语法实验.doc_第5页
资源描述:

《编译原理语法实验.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、实验二:自上而下语法分析一、实验目的:根据某一文法编制调试递归下降分析程序,以便对任意输入的符号串进行分析。根据某一文法编制调试LL(1)分析程序,以便对任意输入的符号串进行分析。本次实验的目的主要是加深对自上而下分析法的理解。二、实验预习提示自下而上分析法的前提改造文法:消除二义性、消除左递归、提取左因子,判断是否为LL(1)文法A.递归下降1、递归下降分析法的功能词法分析器的功能是利用函数之间的递归调用模拟语法树自上而下的构造过程。2、递归下降分析法实验设计思想及算法为G的每个非终结符号U构造一个递归过程,不妨命名为U。U的产生式的右边指出这个过程的代码结构:(1)若是终结符号,则和向前看

2、符号对照,若匹配则向前进一个符号;否则出错。(2)若是非终结符号,则调用与此非终结符对应的过程。当A的右部有多个产生式时,可用选择结构实现。具体为:(1)对于每个非终结符号U->u1

3、u2

4、…

5、un处理的方法如下:U(){ch=当前符号;if(ch可能是u1字的开头)处理u1的程序部分;elseif(ch可能是u2字的开头)处理u2的程序部分;…elseerror()}(2)对于每个右部u1->x1x2…xn的处理架构如下:处理x1的程序;处理x2的程序;…处理xn的程序;(3)如果右部为空,则不处理。(4)对于右部中的每个符号xi①如果xi为终结符号:if(xi==当前的符号){NextCh

6、ar();return;}else出错处理②如果xi为非终结符号,直接调用相应的过程xi()说明:NextChar为前进一个字符函数。B.LL(1)分析法1、LL(1)分析法的功能LL(1)分析法的功能是利用LL(1)控制程序根据显示栈栈顶内容、向前看符号以及LL(1)分析表,对输入符号串自上而下的分析过程。X∈VN‘#’‘S’进栈,当前输入符送a上托栈顶符号放入X若产生式为X®X1X2…Xn按逆序即Xn…X2X1入栈出错X=’#’X∈VTX=aM[X,a]是产生式吗出错X=a读入下一个符号结束是是是是否否否否否是2、LL(1)分析法实验设计思想及算法三、实验过程和指导:(一)准备:1.阅读课

7、本有关章节,2.考虑好设计方案;3.设计出模块结构、测试数据,初步编制好程序。(二)上课上机:将源代码拷贝到机上调试,发现错误,再修改完善。第二次上机调试通过。(三)程序要求:程序输入/输出示例:对下列文法,用两种分析法对任意输入的符号串进行分析:(1)E->TG(2)G->+TG(3)G->ε(4)T->FS(5)S->*FS(6)S->ε(7)F->(E)(8)F->i输出的格式如下:(1)递归下降分析程序输入一以#结束的符号串(包括+—*/()i#):在此位置输入符号串例如:i+i*i#输出结果:i+i*i#为合法符号串备注:输入一符号串如i+i*#,要求输出为“非法的符号串”。(2)L

8、L(1)分析:输入一以#结束的符号串(包括+—*/()i#):在此位置输入符号串例如:i+i*i#输出结果:i+i*i#为合法符号串注意:1.表达式中允许使用运算符(+-*/)、分割符(括号)、字符I,结束符#;2.如果遇到错误的表达式,应输出错误提示信息(该信息越详细越好);3.对学有余力的同学,可以详细的输出推导的过程,即详细列出每一步使用的产生式。分析栈剩余输入串所用产生式Ei+i*i#E->TG4.与读文件有关的函数:FILE*fp;     if((fp=fopen("E:\222.txt","r"))==NULL){  //读取文件内容,并返回文件指针,该指针指向文件的第一个字符

9、 fprintf(stderr,"erroropening.");          exit(1);     }fgetc(fp)从数据流中区下一个字符fopen 文件打开函数,返回指向文件第一个字符的指针(四)程序思路(仅供参考):递归下降分析法:0.定义部分:定义常量、变量、数据结构。1.初始化:从文件将输入符号串输入到字符缓冲区中。2.利用递归下降分析法分析,对每个非终结符编写函数,在主函数中调用文法开始符号的函数。LL(1)分析法:模块结构:1、定义部分:定义常量、变量、数据结构。2、初始化:设立LL(1)分析表、初始化变量空间(包括堆栈、结构体等);3、运行程序:让程序分析一个

10、text文件,判断输入的字符串是否符合文法定义的规则;4、利用LL(1)分析算法进行表达式处理:根据LL(1)分析表对表达式符号串进行堆栈(或其他)操作,输出分析结果,如果遇到错误则显示简单的错误提示。部分代码示例:#include#include#include#includestructStack{chars[30];in

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

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

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