ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:38.02KB ,
资源ID:10706516      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/10706516.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(词法分析器含完整源码.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

词法分析器含完整源码.docx

1、词法分析器含完整源码词法分析实验报告一、实验目的与要求: 1、了解字符串编码组成的词的内涵,感觉一下字符串编码的方法和解读 2、了解和掌握自动机理论和正规式理论在词法分析程序和控制理论中的应用二、实验内容: 构造一个自己设计的小语言的词法分析器: 1、这个小语言能说明一些简单的变量 识别诸如begin,end,if,while等保留字;识别非保留字的一般标识符(有下划线、字符、数字,且第一个字符不能是数字)。识别数字序列(整数和小数);识别:=,=之类的特殊符号以及;,(,)等界符。2、相关过程(函数): Scanner()词法扫描程序,提取标识符并填入display表中 3、这个小语言有顺序

2、结构的语句 4、这个小语言能表达分支结构的语句 5、这个小语言能够输出结果总之这个小语言词法分析器能提供以上所说明到的语法描述的功能三、实验步骤:1、测试评价(1)、测试1:能说明一些简单的变量,如关键字、一般标识符、界符等;(2)、测试2:能输出结果:单词符号(内码形式)、各种信息表(如符号表、常量表等);(3)、测试程序: var x,y,z; begin x:=2; y:=3; if (x+5=y*y) then begin z:=y*y-x; z:=z+x*x; end else z:=x+y; prn z; end.(4)、结果:、从键盘读入;部分结果如下:(类型:该标识符所属的类型

3、,如关键字,变量等;下标:该标识符所对应表(如变量标识符表,常量标识符表等)中其相应的位置,下同)、从文件读入,输出到文件;部分结果如下: 其他测试及结果如下:、出错处理;注:若有错误,则只指出错误,不输出各个表;(5)、评价: 这个小语言程序基本上能完成词法分析阶段的工作,识别诸如begin,if等保留字;识别非保留字的一般标识符(有下划线、字符、数字,且第一个字符不能是数字)。识别数字序列(整数和小数);识别:=,=之类的特殊符号以及;,(,)等界符。在扫描源程序串的同时,能进行一些简单的处理,如删除空格、tab、换行等无效字符,也进行了一些基本的错误处理,如变量长度的判别等。遇到的问题:

4、(a)、判别标识符超过规定长度(20)时,未输出处理结果;(b)、整数长度过长输出结果仍为整数类型3;(c)、对于小数如045,被解释为界符和整数;(d)、对以数字开头的一般标识符的处理,如100nuts被解释为整数类型和标识符,未给出错误提示。如上测试,出现前两个问题时已报错并输出所在行,而后两个问题待解决。2、对小语言的词法规则(正规式)画出一个确定的有限自动机(见附录2、3)四、实验的源代码:(见附录1)五、实验中发现的问题和遇到的困难及解决方法: 由于以前未曾接触过编译原理,在该实验的设计中,的确遇到一定的困难。主要是display表结构的设计,由于语法分析和语义分析还未学习,无法站在

5、全局的角度统筹兼顾, 在表结构设计时,不知该往表结构体中添加哪些内容,可以为后续的工作做铺垫,这是刚开始就遇到的最大的困难,也是最难的。经过分析,我们在现有局限性的基础上,设计出一种折中的表结构,即在表结构中只添加标识符在其相应表中的对应下表,标记符类型码等关键的几处,这样既能 唯一确定一标识符,达到该实验的要求,同时又为表保留了很好的扩充性,以达到后续实验的要求。表结构设计好后,其余的工作就是提取字符串和写入display表,在提取单字符还是双字符组成的运算符时有些麻烦,不过利用数据结构的相关知识也是容易做到。六、总结: 词法分析是构造编译器的起始阶段,也是相应比较简单的一个环节。词法分析的

6、主要任务是:根据构造的状态转换图,从左到右逐个字符地対源程序进行扫描,识别开源程序中具有独立含义的最小语法单位符号或单词,如变量标识符,关键字,常量,运算符,界符等。然后将提取出的标识符以内码的形式表示,即用int类型的数字来表示其类型和在display表中的位置,而无须保留原来标识符本身的字符串,这不仅节省了内存空间,也有利于下一阶段的分析工作。当然,在扫描源程序串的同时,进行一些简单的处理,如删除空格、tab、换行等无效字符,也进行了一些基本的错误处理,如变量长度的判别,有些不合词法规则的标识符判别等。总之,严格说来,词法分析程序只进行和词法分析相关的工作。七、实验感想: 通过此次实验,让

7、我了解到如何设计、编制并调试词法分析程序,加深对词法分析原理的理解;熟悉了构造词法分析程序的手工方式的相关原理,使用某种高级语言(例如C+语言)直接编写此法分析程序。另外,也让我重新熟悉了C+语言的相关内容,加深了对C+语言的用途的理解。附录1(代码)#include #include #include #include #include #include using namespace std;#define Max 655 , , , : , , , ; ymbol,str); tableTableNum.type = 1; ine = nLine; tableTableNum.Index

8、 = i; TableNum +; break; if(i = MaxKeyWord) ndex = WordNum; strcpy(WordWordNum+,str); tableTableNum.type = 2; ymbol,str); tableTableNum.line = nLine; TableNum +; /*常数*/ ype = 3; ype = 4; ndex = DigNum; strcpy(DigitDigNum +,str); strcpy(tableTableNum.symbol,str); tableTableNum.line = nLine; TableNum

9、+; /*运算符*/ else int errorFlag; ype = 6; strcpy(tableTableNum.symbol,str); tableTableNum.line = nLine; tableTableNum.Index = i; TableNum +; chIndex = chIndex + 2; break; if(i = MaxOptBNum) for( int k = 0;k MaxOptANum; k+) if(OptAk = chchIndex) errorFlag = 0; tableTableNum.type = 5; tableTableNum.symb

10、ol0 = chchIndex; tableTableNum.symbol1 = 0; tableTableNum.line = nLine; tableTableNum.Index = k; TableNum +; chIndex +; break; /*界符*/ for(int j = 0;j MaxEndNum;j +) if(Endj =chchIndex) errorFlag = 1; tableTableNum.line = nLine; tableTableNum.symbol0 = chchIndex; tableTableNum.symbol1 = 0; tableTable

11、Num.Index = j; tableTableNum.type = 7; TableNum +; chIndex +; /*其他无法识别字符*/ if(errorFlag != 0 & errorFlag != 1) ype = 8; strcpy(tableTableNum.symbol,str); tableTableNum.line = nLine; tableTableNum.Index = -2; TableNum +; void Trans(double x,int p) n; exit(1); coutout_file_name; (out_file_name); (变量表.

12、txt); (常量表.txt); if() n; exit(1); if() n; exit(1); if() n; exit(1); (ch,Max,#); Scanner(ch, strlen(ch),table,nLine); ype , 0x hex tablei.Index ) endl; ype = 3) long num1; num1 = atoi(tablei.symbol); outCon (0x hex tablei.Index , 0x hex num1 ) endl; if(tablei.type = 4) double num2; num2 = atof(tablei

13、.symbol); outCon (0x hex tablei.Index , 0x hex num2 ) endl; outVar 类型 变量名称 endl; for( i = 0; i WordNum;i +)ype , 0x hex tablei.Index ) endl; cout n常量表:n 下标 常量值 endl; for(i = 0;i TableNum;i+) ype = 3) long num1; num1 = atoi(tablei.symbol); cout (0x hex tablei.Index , 0x hex num1 ) endl; if(tablei.typ

14、e = 4) char *num2; float num,num3; num = atof(tablei.symbol); num2 = gcvt(16,strlen(tablei.symbol),tablei.symbol); num3 = num - floor(num); cout (0x hex tablei.Index , num2; Trans(num3,5) ; cout ) endl; cout n变量表:n类型 变量名称 endl; for( i = 0; i WordNum;i +)0 0034 005678 009100小数点小数点 非= 且 非 11 001201301401500160180170 = 非= +、*、/、=、# : = (、)、,、;、:、 非 、

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1