欢迎来到天天文库
浏览记录
ID:19621979
大小:386.09 KB
页数:63页
时间:2018-10-04
《编译原理实验指导书(李宏芒)》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、《编译原理》实验指导书李宏芒编写适用专业:计算机科学与技术合肥工业大学计算机与信息学院2012年12月63前言《编译原理》是计算机专业的一门核心课程,在计算机本科教学中占有十分重要的地位。由于《编译原理》课程兼有很强的理论性和实践性,并且编译程序构造的算法比较复杂,因而让学生在学习时普遍感到内容抽象、不易理解,难易掌握。但是掌握编译原理的基本理论和设计思想是非常重要的,尤其是将本课程的理论知识与计算机应用中的许多领域紧密联系与广泛应用结合,将有利于提高学生专业素质和适应社会多方面需要的能力,因此,通过理论授课和上机实践相结合,使学生对编译的基本概念、原理和方法有完整的和清楚的
2、理解,并能正确地、熟练地加以运用;通过实验逐步提高学生的编程能力和调试程序的能力以及解决实际问题的能力,使学生培养出扎实的软件开发基本技能,并养成良好的编程风格,为进一步学习后续课程和将来从事应用软件开发奠定良好的基础。63实验课时具体内容安排如下:序号实验名称课时必(选)做实验一词法分析设计4必做实验二LL(1)预测分析4必作实验三LR语法分析设计4必做实验四逆波兰表达式的产生及计算3选做实验五应用DAG进行局部优化3选做实验六C语言子集编译程序课外选做一、实验课的性质和目的(1)深刻理解程序语言编译系统的结构及各部分的功能。(2)熟练掌握设计和构造程序语言编译系统的基本原
3、理和技术。(3)能独立编写清晰、工整、结论正确的编译原理的源程序。(4)能学会上机进行正确调试,并进行程序修改。即培养发现程序错误,排除错误的能力和经验。二、实验课的基本要求:(1)掌握编译程序的功能和结构。(2)掌握词法分析器的设计方法与实现步骤加深对讲授内容的理解,尤其是一些语法给定,通过上机实验帮助掌握。(3)掌握语法分析器的设计方法与实现步骤。(4)掌握符号表和存储空间的组织。(5)掌握代码优化的作用与实现方法(6)掌握错误的诊断和校正方法。三、主要实验教学方法实验前,由任课教师落实实验任务,每个学生必须事先独立完成好程序的设计的源程序编写工作。实验课上对疑难点作集中
4、辅导。实验过程中随时针对不同63的情况作个别启发式辅导。实验后,学生撰写并提交实验报告。最后,由实验教师根据每个学生的编程、上机调试能力、编程能力和实验结果及实验报告综合评定学生的实验成绩。四、实验的重点与难点:对词法分析设计、语法分析设计和中间代码的产生、代码优化等是本课程实践性环节的重点和难点。五、实验教学手段通过本课程的课内实验,使学生上机编程、调试来验证和巩固所学的编译原理理论及概念,逐步掌握词法分析的设计方法及实现技术。软件实验室为为每个学生提供了一台具有WINDOWS98/XP/NT/2000操作系统的计算机和VC++/VB/JAVA/TC等软件环境。六、实验考核
5、成绩《编译原理》是一门实践性很强的课程,要求在教学过程中必须十分重视实践性环节,包括平时练习作业、记分作业、上机实验等。尤其是要注重上机实验的重要性,必须通过上机实践才能真正掌握所学的知识和技能,所以要特别强调实验也将作为考核成绩的依据。实验成绩占平时成绩的20%。每次必须完成规定的实验内容,并及时写出实验报告。七、实验报告内容:1.实验题目、班级、学号、姓名、完成日期。2.写出数据结构及生成的算法描述。3.画出算法流程图。4.打印出源程序代码和给出测试的结果。5.实验的评价、收获与体会。写出在调试过程中出现的问题和解决的措施;分析讨论对策成功或失败的原因。63目录前言2实验
6、一词法分析设计6实验二LL(1)分析法13实验三LR(1)分析法16实验四逆波兰表达式的产生及计算21实验五应用DGA进行局部优化26实验六C语言子集编译程序(可选)3063实验一词法分析设计实验学时:4实验类型:综合实验要求:必修一、实验目的通过本实验的编程实践,使学生了解词法分析的任务,掌握词法分析程序设计的原理和构造方法,使学生对编译的基本概念、原理和方法有完整的和清楚的理解,并能正确地、熟练地运用。二、实验内容用VC++/VB/JAVA语言实现对C语言子集的源程序进行词法分析。通过输入源程序从左到右对字符串进行扫描和分解,依次输出各个单词的内部编码及单词符号自身值;若
7、遇到错误则显示“Error”,然后跳过错误部分继续显示;同时进行标识符登记符号表的管理。以下是实现词法分析设计的主要工作:(1)从源程序文件中读入字符。(2)统计行数和列数用于错误单词的定位。(3)删除空格类字符,包括回车、制表符空格。(4)按拼写单词,并用(内码,属性)二元式表示。(属性值——token的机内表示)(5)如果发现错误则报告出错63(6)根据需要是否填写标识符表供以后各阶段使用。单词的基本分类:u关键字:由程序语言定义的具有固定意义的标识符。也称为保留字例如if、for、while、pr
此文档下载收益归作者所有