- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
语法分析器的实现
目录
1.语法分析方法 1
1.1 实验内容 1
1.2 语法分析器的实现 2
1.3 语法分析的程序流程图 2
2.程序设计 3
2.1 总体设计 3
2.2 子程序设计 8
3.程序中的结构说明 10
3.1 重要函数介绍及函数代码 10
4.程序测试 29
4.1 程序测试截图: 29
5 实验总结 31
1.语法分析方法
1.1 实验内容
语法分析程序用LL(1)语法分析方法。首先输入定义好的文法书写文件(所用的文法可以用LL(1)分析),先求出所输入的文法的每个非终结符是否能推出空,再分别计算非终结符号的FIRST集合,每个非终结符号的FOLLOW集合,以及每个规则的SELECT集合,并判断任意一个非终结符号的任意两个规则的SELECT集的交集是不是都为空,如果是,则输入文法符合LL(1)文法,可以进行分析。
题目:
已知文法G[S]:
S→MH|a H→LSo|ε K→dML|ε L→eHf M→K|bLM
判断G 是否是LL(1)文法。
解:文法展开为:
0) S→M H
1) S→a
2) H→L S o
3) H→ε
4) K→d M L
5) K→ε
6) L→e H f
7) M→K
8) M→b L M
非终结符 FIRST 集 FOLLOW 集 S {a,d,b,ε,e} {#,o} M {d,ε,b}. {e,#,o} H {ε,e} . {#,f,o}.... L {e}.... {a,d,b,e,o,#} K {d,ε}.. {e,#,o}... 对相同左部的产生式可知:
SELECT(S→M H)∩SELECT(S→a) ={ d,b ,e,#,o }∩ { a }=空集
SELECT(H→L S o)∩SELECT(H→ε) ={ e }∩ { #,f,o }=空集
SELECT(K→d M L)∩SELECT(K→ε) ={ d }∩ { e,#,o }=空集
SELECT(M→K)∩SELECT(M→b L M) ={ d,e,#,o }∩ { b }=空集
所以文法是LL(1)的。
1.2 语法分析器的实现
语法分析是编译过程的核心部分,它的主要任务是按照程序的语法规则,从由词法分析输出的源程序符号串中识别出各类语法成分,同时进行词法检查,为语义分析和代码生成作准备。这里采用自顶向下的LL(1)分析方法。
该程序可分为如下几步:
(1)读入文法
(2)判断正误
(3)若无误,判断是否为LL(1)文法
(4)若是,构造分析表;
(5)由句型判别算法判断输入符号串是为该文法的句型。
1.3 语法分析的程序流程图
2.程序设计
2.1 总体设计
2.1.1 求能推出空的非终结符集
Ⅰ、实例中求直接推出空的empty集的算法描述如下:
void emp(char c){ 参数c为空符号
char temp[10];定义临时数组
int i;
for(i=0;i=count-1;i++)从文法的第一个产生式开始查找
{
if 产生式右部第一个符号是空符号并且右部长度为1,
then将该条产生式左部符号保存在临时数组temp中
将临时数组中的元素合并到记录可推出符号的数组empty中。
}
Ⅱ、求某一符号能否推出
int _emp(char c)
{ //若能推出,返回1;否则,返回0
int i,j,k,result=1,mark=0;
char temp[20];
temp[0]=c;
temp[1]=\0;
存放到一个临时数组empt里,标识此字符已查找其是否可推出空字
如果c在可直接推出空字的empty[]中,返回1
for(i=0;;i++)
{
if(i==count)
return(0);
找一个左部为c的产生式
j=strlen(right[i]); //j为c所在产生式右部的长度if 右部长度为1且右部第一个字符在empty[]中. then返回1(A-B,B可推出空)
if 右部长度为1但第一个字符为终结符,then 返回0(A-a,a为终结符)
else
{
for(k=0;k=j-1;k++)
{
查找临时数组empt[].并标记mark-=1(A-AB)
if 找到的字符与当前字符相同(A-AB)
结束本次循环
else(mark等于0)
查找右部符号是否可推出空字,把返回值赋给result
把当前符号加入到临时数组empt[]里.
}
if 当前字符不能推
您可能关注的文档
- 论元认知理论在英语阅读教学中的应用.doc
- 论元认知理论在高中英语阅读教学中用.doc
- 论公允价值计量属性在实务中的应用探讨.doc
- 论农村女儿养老现状.doc
- 论初中生美术兴趣的培养.doc
- 论商业银行业务创新问题及对策---以中信银行为例.doc
- 论国内4S店的运作手段与发展前景.doc
- 论国有企业激励机制改革.doc
- 论孔子的廉政思想.doc
- 论寿险代理人队伍的招募和留存.doc
- 建设工程质量安全管理标准化图集(安全篇2024版)ppt230页.pptx
- 《油气储存企业安全风险评估细则(2025年修订)》解读.pptx
- 2025年《危大工程专项施工方案严重缺陷清单专题培训》ppt120页_1230.pptx
- 中建分部分项检验批划分方案、资料目录策划编制要点ppt75页.pptx
- 某项目智慧工地示范项目应用成果介绍75页_5843.pptx
- 2025年中国风筝无人机LED夜光编队编程师应聘面试模拟题及答案.doc
- 2025年中国鞍钢集团招聘笔试题库附答案.doc
- 2025年中国鞍钢集团招聘面试预测题及答案.doc
- 临床器械实验培训试题及答案2025年版.docx
- 中石化《两个责任》解读分析.ppt
文档评论(0)