- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理实验报告
实验名称: 编写递归下降语法分析程序
实验类型: 验证型实验
指导教师:
专业班级:
姓名:
学号:
电子邮件:
实验地点:
实验成绩:
日期:201 年 5 月 25 日
实验目的
通过设计、调试递归下降语法分析程序,实现用词法分析从源程序中分出各种单词并对词法分析程序提供的单词序列进行语法检查和结构分析,熟悉并掌握常用的语法分析方法。
明确语法分析器的功能,在词法分析的基础上进一步分析程序;
加深对课堂教学的理解;
提高语法分析方法的实践能力;
通过本实验,应达到以下目标:
1、掌握递归下降的结构模型。
2、掌握语法分析的实现方法。
3、上机调试编出的语法分析程序。
实验过程
有了第一次的经验,这次还是先画出流程图。
流程图如下:
三、实验结果
语法分析实验成功。
赋值时少写数字:
缺少括号时:
附(txt文档内容):
程序运行后写入的:
四、讨论与分析
这个程序是在实验一的基础上写的,用的递归下降的方法。不止能识别,还能判断一些语法的正误。刚看书上附录的代码时,头都大了,觉得自己完成不了。但是真正一步一步看下去,画出了流程图,就很清晰明白了。一个函数嵌套一个函数,一步一步往细处走,刚开始是大体轮廓,然后就深入,直到最低层的判断。
书上的程序还是有一些漏洞,比如要写多个语句时,if,for,while在语句内不能加括号,不然只能分析至第一个,遇到“}”就结束了,所以在txt文件里写程序代码的时候要注意不能加{},这样才可以全部printf出来。
五、附录:关键代码(给出适当注释,可读性高)
全部代码附vc++,这里粘贴主程序,以及各类函数。
int TESTparse();
int TESTscan();
int program();
int compound_stat();
int statement();
int expression_stat();
int expression();
int bool_expr();
int additive_expr();
int term();
int factor();
int if_stat();
int while_stat();
int for_stat();
int write_stat();
int read_stat();
int declaration_stat();
int declaration_list();
int statement_list();
int compound_stat();
#includestdio.h
#includectype.h
int TESTscan();
int TESTparse();
FILE *fin,*fout;
void main()
{
int es=0;
es=TESTscan();
if(es0)
printf(词法分析有错!编译停止!\n);
else
{
printf(词法分析成功!\n);
}
if(es==0)
{
es=TESTparse();
if(es==0)
printf(语法分析成功!\n);
else
printf(语法分析错误!\n);
}
}
六、实验者自评
这个实验比第一个有难度,是在第一个完成的基础上进行的。把这里面的递归和嵌套搞明白了,整个程序就好写了。
感觉还可以加一些东西,比如这个程序识别类型只能是int整型,可以加上char,float,double等。在语句里可以多加一些常用的,do while,scanf,printf,等。
and work. Many classes established the duty monitor system, let every students have class member services and for the class t
文档评论(0)