欢迎来到天天文库
浏览记录
ID:17379769
大小:351.00 KB
页数:22页
时间:2018-08-30
《编译原理课程设计报告模板》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、《编译原理课程设计》报告MiniC编译器设计与实现分组序号:13设计地点:微301、文理楼110电子邮件:分组成绩:任课教师:李村合专业班级计算机12-班姓名学号成绩比例(%)162017171515成绩2014年12月19日20目录1课程设计目的12课程设计内容13课程设计原理14系统需求分析44.1MiniC编译器总体流程图54.2功能需求64.3用到的主要关键词:84.4汇编成可执行文件84.5MiniC语言的文法85系统设计与实现85.1BY13编译器的主要功能模块85.2词法分析子程序85.3语法语义分析子程序86系统测试与运行结果分析96.1测试程序196.2测试程序2
2、96.3测试程序396.4测试结果1106.5测试结果2136.6测试结果3167心得体会19201课程设计目的(1)根据所掌握的编译原理课程的基本知识,编写出一个MiniC编译器;(2)增强阅读和编写程序的能力;(3)理解词法分析、语法分析和语义分析在编译程序中的作用;(4)掌握词法分析、语法分析和语义分析程序的实现方法;(5)实现MiniC编译器的编辑、编译、连接和运行。2课程设计内容用MFC编写一个可视化的MiniC编译器,要求界面美观,使用方便,能够实现自定义MiniC语言的编译。ü支持的语句和运算:(1)数据类型:int,char,void,float(2)语句:赋值(=
3、),if,while,for(3)数学运算:+,-,*,/(4)关系运算:==,>,<,>=,<=,!=(5)逻辑运算:&&,
4、
5、,!(6)支持函数的定义、调用(7)支持复合语句,即{}包含的语句(8)注释:C类型的多行注释/**/和C++类型的单行注释//3课程设计原理MiniC语言可以看成C语言的子集,它的编译程序是一个编译执行环境。MiniC的编译程序和目标程序的执行程序都是用C++语言编写的,因此MiniC语言可在配备C语言的任何机器上实现。它的编译过程采用从左到右扫描输入符号串,进行最左推导,再向右看一个符号的方式,以语法分析程序为核心,词法分析和汇编代码生成程序都是独立
6、的过程。当语法分析需要读取输入符号串时就调用词法分析程序;而当语法分析正确后,需要生成相应的目标代码(老师只要求到汇编代码,在本程序中则更进一步,是目标文件.obj文件和可执行的目标文件.exe文件)时,则调用汇编代码生成程序和创建EXE文件程序。用表格管理程序建立变量、常量和过程标识符的说明与引用之间的信息联系。当源程序编译正确时,编译程序自动调用执行程序,对目标代码进行执行,并按用户程序的要求输入数据和输出运行结果。(1)运行BY13程序,打开Exp.mc文件。20(2)选择菜单编译(C)->生成汇编代码(G)。20(3)选择菜单编译(C)->创建EXE文件(B),生成可执行的
7、目标文件。(4)选择菜单编译(C)->运行(R),出现如下图所示的结果。204系统需求分析MiniC语言编译过程采用从左到右扫描输入符号串,进行最左推导,再向右看一个符号的方式,对源程序分别进行词法分析、语法分析、语义分析、中间代码生成、目标代码生成和可执行程序生成,此外,用表格管理程序建立变量、常量和过程标识符的说明与引用之间的信息联系.用出错处理程序对词法和语法分析研究遇到的错误给出在源程序中出错的位置和错误性质,它的工作过程如下所示:输入源代码->词法分析->语法分析->汇编代码生成->exe文件生成->运行4.1MiniC编译程序总体介绍该编译器的运行过程是编辑源文件保存后
8、,生成汇编代码时使用汇编代码生成程序CAsmCodeGenerator类,调用该类的成员函数genCodeSeg()来生成代码段和genPreSeg()来生成数据段,最后调用emitCode();当然我们在汇编代码生成时应该使用语义分析子程序CAnalyzer类对词法和文法出现的各种情况进行展开分析。4.2功能需求(1)用C++语言实现了类C语言,叫做MiniC语言;(2)使用LL(1)文法,从左到右扫描输入符号串,进行最左推导,再向右看一个符号;采用递归子程序法实现语法分析,并用C++语言实现了词法分析器、语法分析器、汇编代码生成器,能直接生成intel80x86汇编代码。(3)
9、在声明中实现了对静态常量、变量和函数声明的支持;赋值语句的=,基本的数学运算+、-、*、/;(4)使用函数实现了对过程的调用;(5)使用{}实现复合语句;20(6)使用函数read()来同时读入一个或多个数据,使用函数write()来同时输出一个或多个数据,而函数printf()只能用来输出字符串;(7)在循环分支语句中实现了if语句,if……else……语句,for(…,……,……)…语句,while……语句;(8)关系表达式包括==(等于)、!=(不等于)、<、<
此文档下载收益归作者所有