编译技术课程设计

编译技术课程设计

ID:33592899

大小:526.50 KB

页数:14页

时间:2019-02-27

编译技术课程设计_第1页
编译技术课程设计_第2页
编译技术课程设计_第3页
编译技术课程设计_第4页
编译技术课程设计_第5页
资源描述:

《编译技术课程设计》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、编译技术课程设计班级网络1102学号姓名徐静指导老师年轶2014年6月第13页目录一、目的2二、题目2三、要求2四、实验环境2五、系统实现2六、程序运行结果3七、总结3第13页一、目的通过《编译原理》课程设计进一步理解高级语言在计算机中的执行过程,加深对编译原理中重点算法和编译技术的理解,掌握词法分析、语法分析、语义分析、代码生成和报错处理等理论与实践的结合,提高自己的编程能力,培养好的程序设计风格。同时通过某种可视化编程语言的应用,具备初步的Windows环境下的编程思想。二、题目输入文法,自动生成分析表,并完成语法分析工作三、要求题目

2、3文法编译器的自动生成器输入文法,自动生成分析表,并完成语法分析工作。语法分析方法可以是:LL(1)分析法或LR分析法。为文法构造分析表,并对输入串进行语法分析,判别是否符合语法规则,如果不符合,则输出错误信息。输入:文法,文法符号串输出:分析表、分析栈、分析结果四、实验环境开发环境VisualStudio6.0语言C++五、系统实现1.分析方法说明所谓LL(1)分析法,就是指从左到右扫描输入串(源程序),同时采用最左推导,且每次直接推导只需向前看一个输入符号,便可确定当前所应当选择的规则。实现LL(1)分析的程序又称为LL(1)分析程序

3、或LL(1)分析器。我们知道一个文法要能进行LL(1)分析,那么这个文法应该满足:无二义性,无左递归,无左公因子。当文法满足条件后,再分别构造文法每个非终结符的FIRST和FOLLOW集合,然后根据FIRST和FOLLOW集合构造LL(1)分析表,最后利用分析表,根据LL(1)语法分析构造一个分析器。LL(1)的语法分析程序包含了三个部分,总控制程序,预测分析表函数,先进先出的语法分析栈,本程序也是采用了同样的方法进行语法分析,该程序是采用了C++语言来编写。2.分析表的构造算法在构造LL(1)预测分析表之前,首先要构造该文法的每个非终结

4、符的FIRST和FOLLOW集合,按照下面描述的算法来构造这两个集合。 ①FIRST集合的构造算法: (1)若X∈VT,则FIRST(X)={X}。 (2)若X∈VN,且有产生式X→a„„,则把a加入到FIRST(X)中;若X→ε也是一条产生式,则把ε也加到FIRST(X)中。 (3)若X→Y„„是一个产生式且Y∈VN,则把FIRST(Y)中的所有非ε-元素都加到FIRST(X)中;若X→Y1Y2„Yk是一个产生式,Y1,„,Yi-1都是非终结符,而且,对于任何j,1≤j≤第13页i-1,FIRST(Yj)都含有ε(即Y1„Yi-1*Þε

5、),则把FIRST(Yj)中的所有非ε-元素都加到FIRST(X)中;特别是,若所有的FIRST(Yj)均含有ε,j=1,2,„,k,则把ε加到FIRST(X)中。 连续使用上面的规则,直至每个集合FIRST不再增大为止。 ②FOLLOW集合的构造算法: (1)对于文法的开始符号S,置#于FOLLOW(S)中; (2)若A→αBβ是一个产生式,则把FIRST(β)

6、 {ε}加至FOLLOW(B)中; (3)若A→αB是一个产生式,或A→αBβ是一个产生式而βÞε(即ε∈FIRST(β)),则把FOLLOW(A)加至FOLLOW(B)中。 

7、连续使用上面的规则,直至每个集合FOLLOW不再增大为止3.数据结构变量定义:structpRNode/*产生式右部结构*/structpNodestructcollectNodestructcollectNode*first[MaxVnNum+1];/*first集*/structcollectNode*follow[MaxVnNum+1];/*follow集*/charVn[MaxVnNum+1];/*非终结符集*/intvnNum;charVt[MaxVtNum+1];/*终结符集*/intvtNum;structpNodeP[Ma

8、xRuleNum];intPNum;charbuffer[MaxPLength+1];charst[MaxStLength];/*要分析的符号串*/intanalyseTable[MaxVnNum+1][MaxVtNum+1+1];intanalyseStack[MaxStackDepth+1];/*分析栈*/inttopAnalyse;/*分析栈顶*/类关系图:③LL(1)分析过程主要包括以下四个动作:第13页替换:当XÎVN时选相应产生式的右部b去替换X。此时X出栈,b逆序入栈。匹配:当XÎVT时它与a进行匹配,其结果可能成功,也可能

9、失败,如果成功则符号栈中将X退栈并将输入流指针向前移动一位,否则报错。接受:当格局为(#,空#)时报告分析成功。报错:出错后,停止分析。并给出相应的错误提示信息。驱动程序框图如下:4.函数说明

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

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

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