编译原理-词法分析器报告

编译原理-词法分析器报告

ID:12450378

大小:97.00 KB

页数:9页

时间:2018-07-17

编译原理-词法分析器报告_第1页
编译原理-词法分析器报告_第2页
编译原理-词法分析器报告_第3页
编译原理-词法分析器报告_第4页
编译原理-词法分析器报告_第5页
资源描述:

《编译原理-词法分析器报告》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

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

5、inti,j;str[0]=ch;ch=getchar();for(i=1;isalpha(ch);i++){str[i]=ch;ch=getchar();}for(j=0;j<6;j++){if(strcmp(str,keywords[j])==0){Token[tk].id=j+3;strcpy(Token[tk].value,str);tk++;-9-return;}}for(;isalnum(ch);i++){str[i]=ch;ch=getchar();}Token[tk].id=1;strcpy(Token[tk].value,str);tk++;return;}voidflag(

6、){charstr[2]={""};inti;str[0]=ch;ch=getchar();for(i=0;i<7;i++){if(strcmp(str,jF[i])==0){Token[tk].id=i+9;-9-strcpy(Token[tk].value,str);tk++;return;}}}voidcon(){charstr[20]={""};inti;str[0]=ch;ch=getchar();for(i=1;isdigit(ch);i++){str[i]=ch;ch=getchar();}Token[tk].id=2;strcpy(Token[tk].value,str

7、);tk++;return;}intmain()-9-{printf("请输入语句.输入完成后键入@,按Enter执行!");printf("================================");printf("============词法分析============");printf("================================");ch

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。