资源描述:
《编译原理-词法分析器报告》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、昆明理工大学信息工程与自动化学院学生实验报告(2011—2012学年第1学期)课程名称:编译原理开课实验室:信自楼机房4442011年11月14日年级、专业、班学号姓名成绩实验项目名称简单样本语言的词法分析器指导教师教师评语该同学是否了解实验原理:A.了解□B.基本了解□C.不了解□该同学的实验能力:A.强□B.中等□C.差□该同学的实验是否达到要求:A.达到□B.基本达到□C.未达到□实验报告是否规范:A.规范□B.基本规范□C.不规范□实验过程是否详细记录:A.详细□B.一般□C.没有□教师签名:年月日一、实验目的及内容实验目的:能够采用C编程语言实现简单的词法分析程序,设计、编制并调试一
2、个词法分析程序,加深对词法分析原理的理解。实验内容:实现我们定义的语言的词法分析器。这种语言的程序结构很简单,语法相当于c的函数体,即由一对大括号括起来的语句序列,没有过程或函数。声明语句、表达式语句及控制语句的写法都与c类似,但规定:一条声明语句只能声明一个整型变量,没有数组;控制语句只是if、for和while三个语句,这三个语句本身也可以包含语句序列;表达式仅局限于布尔表达式和整型算术表达式,布尔表达式由对两个算术表达式的比较组成,该比较使用<,>,<=,>=,==,!=比较运算符;算术表达式可以包括整型常数、变量以及+,-,*,/这四个运算符。另外,还可以有复合语句。用read和wri
3、te语句实现输入输出。注释用/*和*/括起来,但注释不能嵌套。-9-一、实验原理及基本技术路线图(方框原理图或程序流程图)词法分析器流程图:三、所用仪器、材料(设备名称、型号、规格等或使用软件)1台PC及VISUALC++6.0软件。-9-四、实验方法、步骤(或:程序代码或操作过程)源代码:#include#include#include#includecharch;char*keywords[]={"if","then","begin","end","while","do"};char*jF[]={"+","*","
4、/","=","-",";"};typedefstruct{intid;charvalue[20];}TokenType;TokenTypeToken[40];inttk=0;intline=1;voiderror(){printf("ERRORInLine%d",line);return;}-9-voiddisplay(){inti;printf("");for(i=0;i