论文简单的编译原理语法分析Word文档格式.doc
- 文档编号:13019240
- 上传时间:2022-10-02
- 格式:DOC
- 页数:22
- 大小:138KB
论文简单的编译原理语法分析Word文档格式.doc
《论文简单的编译原理语法分析Word文档格式.doc》由会员分享,可在线阅读,更多相关《论文简单的编译原理语法分析Word文档格式.doc(22页珍藏版)》请在冰豆网上搜索。
目录
论文总页数:
22页
1引言 1
1.1项目背景 1
1.2目标 1
1.3名词解释 1
1.4算法简介 2
1.4.1自顶向下分析 2
1.4.2递归子程序 3
1.4.3LL(K)分析方法 4
1.4.4LL
(1)分析方法 4
1.4.5LL
(1)分析表 5
2系统流程图 6
2.1程序流程图 6
2.2系统模块流程图 7
3系统实施 7
3.1文件读取模块 8
3.1.1文件读取使用的CommonDialog控件介绍 8
3.1.2文法左递归的判断 9
3.2算法分析模块 9
3.2.1求select集 9
3.2.2求first集 10
3.2.3求follow集 10
3.3分析表构造模块 12
3.3.1构造文法分析表 12
3.3.2A:
:
=aβ规则 13
3.3.3A:
=Dβ规则 13
3.3.4A:
=ε规则 13
3.4句子分析模块 13
3.4.1读取句子 14
3.4.2分析句子 14
4特殊问题及解决方法 14
4.1Select集的求解 15
4.1.1问题描述 15
4.1.2解决方案 15
4.1.3解决结果 15
4.2为ListBox添加水平滚动条 15
4.2.1问题描述 15
4.2.2解决方案 15
4.2.3解决结果 16
5结果测试 16
5.1测试正确文法 16
5.2测试错误文法 19
结论 20
参考文献 20
1引言
1.1项目背景
编译原理是计算机专业中最难的一门课程,在理论上它要求学生掌握有关形势语言和自动机的抽象概念,在技术上要求学生能够熟练地利用各种数据结构进行编程。
编译程序是现代计算机系统的基本组成部分之一。
在编译原理的教学过程中,语法和语义分析阶段关于算法的讲解都需要对算法进行详细的分析,包括算法条件的判断,文法分析表的构造过程,文法分析表的具体生成,针对文法的句子的分析过程等。
这些过程往往需要占用大量时间来分析、制表等。
教学主要是对这些过程的讲解和分析,没有必要花这么多的时间来做这些工作。
本软件的主要任务就是利用程序来完成算法的上述相关过程,节约教学时间。
1.2目标
《一个编译原理语法分析器的设计与实现》
1.主要通过文本方式获取相关文法,并实现以下相关操作:
2.判断文法是否符合LL
(1)的要求
3.获取文法的终结符和非终结符
4.求文法的select集(其中包括first集和follow集的求解)并判断select集是否符合LL
(1)算法的要求
5.根据文法和select集构造文法分析表
6.根据文法分析表判断输入的句子是否符合文法
1.3名词解释
语法分析:
逐一分析词法分析所得的属性字,检查其中的语法错误,如果没有发现语法错误,则给出正确的语法结构。
句子的分析:
句子的分析实际就是分析源程序中的语句是否符合给定的文法。
文法:
对语言结构的定义和描述,即在形式上用于描述和规定语言结构。
由若干条规则组成。
规则:
为一个二元组,通常格式为U:
:
=x或U→x;
其中U为规则的左部,是一个符号;
x是规则的右部,是一贯有穷字符串。
规则又称为产生式。
BNF表示法:
即巴科斯范式表示法,它引进了符号“|”,符号“|”表示“或”。
运用符号“|”把相同左部的规则缩写在一起,这样显得文法更为紧凑。
文法G[Z]:
规则的非空有穷集合,其中Z为文法的识别符号或开始符号,它至少要在一条规则的左部出现。
字汇表:
在文法中,由全部规则的左部和右部中的所有符号组成的符号集。
非终结符:
文法中出现在规则左部的符号,它们组成的集合称为非终结符集。
终结符:
文法中凡不属于非终结符集的符号,它们组成的集合称为终结符集。
递归:
同一操作或一组操作的连续重复,其实质上是处理过程的性质,在这种过程的每一步都要用到它自身的上一步或上几步的结果。
递归定义:
在定义某种事物时又用到其本身。
直接左递归规则:
型如U:
=Uy的规则称为直接左递归规则。
First集:
首符号集。
Follow集:
向前看集。
Select集:
可选集。
LL
(1)文法:
对于文法G(S),其每个非终结符的不同规则具有不相交的Select集,则称该文法为LL
(1)文法。
1.4算法简介
1.4.1自顶向下分析
对于文法G[Z],给顶一个待分析的句子(字符串),自顶向下分析的基本思想是从识别符号Z开始,根据文法试着建立一个推导序列,若得到所给的句子,则句子得到识别,表明其结构符合文法,如果经过各种推导都不能得到所分析的句子,则该符号串不符合文法。
或者说,从根结点出发,自上而下地建立一颗语法树,其未端结点按从左到右的顺序连接起来,构成给定的符号串,则符号串得到识别。
例:
设有文法G[N]和符号串25N
D
N
N:
=D|ND
D:
=0|1|2|…|9
根据文法有:
5
NÞ
NDÞ
DDÞ
2DÞ
25;
因此我们说25符合此文法
2
图1G[N]过程分析
自顶向下分析的难点及解决办法:
1.自顶向下分析的难点
对于形如:
U:
=x1|x2|…|xn的规则,可能需要对所有的规则都要试探。
2.难点的解决办法
该解决办法是把文法中每个非终结符号A的右部称为A的候选式,对候选式的选择,则根据当前输入符号来决定。
方法:
首先对文法的每个规则A:
=b求可选集Select(A:
=b)。
当e¹
b时,则对于当前输入的符号a,若有aÎ
First(b),则可以选用规则A:
=b进行推导。
若对于某非终止符号有n条规则(即有n个候选式)的处理方法:
1.首符号集不相同的解决办法
对于文法,有A:
=x1|x2|…|xn,其右部的n个候选式的首符号集均不相同:
即First(xi)∩First(xj)=Æ
(i¹
j),对于待分析的符号串,如果最左的非终结符号为A,若其句子中对应的下一个符号(当前输入符号)为a,且有aÎ
First(xk),则选择规则A:
=xk来作为推导的候选式。
设有文法G[Z],和句子bbabaax
Z:
=aV|bZ
V:
=baZ|x
Select(Z:
=aV)={a};
=bZ)={b};
Select(V:
=baZ)={b};
=x)={x};
ZÞ
bZÞ
bbZÞ
bbaVÞ
bbabaZÞ
bbabaaVÞ
bbabaax
(babaax)(abaax)(baax)(ax)(x)
2.首符号相同的解决办法
=x1|x2|…|xn,若有First(xi)∩First(xj)Æ
¹
(i¹
j),采用试探法:
即从首字符中有输入符号的多个候选式中任选一个来试探,如果不成功,就换另一个接着试。
试探法有可能形成回溯
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 论文 简单 编译 原理 语法分析