收藏 分享(赏)

实验1 词法分析实验报告.doc

上传人:dzzj200808 文档编号:2311205 上传时间:2018-09-10 格式:DOC 页数:7 大小:74.50KB
下载 相关 举报
实验1 词法分析实验报告.doc_第1页
第1页 / 共7页
实验1 词法分析实验报告.doc_第2页
第2页 / 共7页
实验1 词法分析实验报告.doc_第3页
第3页 / 共7页
实验1 词法分析实验报告.doc_第4页
第4页 / 共7页
实验1 词法分析实验报告.doc_第5页
第5页 / 共7页
点击查看更多>>
资源描述

1、实验 1 词法分析实验报告一、 实验目的调试并完成一个词法分析程序,加深对词法分析原理的理解。二、 实验要求1、 待分析的简单语言的词法(1) 关键字:begin if then while do end所有关键字都是小写。(2) 运算符和界符::= + * / = = ; ( ) #(3) 其他单词是标识符(ID)和整型常数(NUM) ,通过以下正规式定义:ID=letter(letter| digit)*NUM=digit digit *(4) 空格由空白、制表符和换行符组成。空格一般用来分隔ID、 NUM,运算符、界符和关键字,词法分析阶段通常被忽略。2、 各种单词符号对应的种别码单词符

2、号 种别码 单词符号 种别码begin 1 : 17if 2 := 18then 3 20while 4 :m=0;tokenm+=ch;ch=progp+;if(ch=)syn=24;tokenm+=ch;elsesyn=20;p-;break;case:m=0;tokenm+=ch;ch=progp+;if(ch=)syn=18;tokenm+=ch;elsesyn=17;p-;break;case*:syn=13;token0=ch;break;case/:syn=14;token0=ch;break;case+:syn=15;token0=ch;break;case-:syn=16;t

3、oken0=ch;break;case=:syn=25;token0=ch;break;case;:syn=26;token0=ch;break;case(:syn=27;token0=ch;break;case):syn=28;token0=ch;break;case#:syn=0;token0=ch;break;casen:syn=-2;break;default: syn=-1;break;void main()p=0;row=1;cout0 then x:=2*x+1/3; end#输出结果2、源程序(包括上式未有的 while、do 以及判断错误语句):beginx9-x;end#输

4、出结果五、 收获(体会)与建议通过此次实验,让我了解到如何设计、编制并调试词法分析程序,加深对词法分析原理的理解;熟悉了构造词法分析程序的手工方式的相关原理,根据识别语言单词的状态转换图,使用某种高级语言(例如 C+语言)直接编写此法分析程序。另外,也让我重新熟悉了 C+语言的相关内容,加深了对 C+语言的用途的理解。比如:main()函数中,用 cinch;语句得到 ch 值的话,给定源程序的结果第一行得到的是(10,beginx) ,因为得到的字符串中省略了空格,改用 cin.get(ch);问题便解决了。另外,我在程序中加入了 row 变量,以便能够准确得到错误所在。实验二时发现怎么出结果都会出现一个缺:=错误,便回头检查代码才发现实验一时的 scaner()函数最后的:和:=的种别码互相写错了,所以回过头来重新修正了代码和实验结果图。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 高等教育 > 大学课件

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报