简单词法分析程序设计

简单词法分析程序设计

ID:6668960

大小:44.50 KB

页数:12页

时间:2018-01-21

简单词法分析程序设计_第1页
简单词法分析程序设计_第2页
简单词法分析程序设计_第3页
简单词法分析程序设计_第4页
简单词法分析程序设计_第5页
资源描述:

《简单词法分析程序设计》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、实验一 简单词法分析程序设计一、实验目的了解词法分析程序的基本构造原理,掌握词法分析程序的手工构造方法。二、实验内容1、了解编译程序的词法分析过程。2、根据PASCAL语言的说明语句形式,用手工方法构造一个对说明语句进行词法分析的程序。该程序能对从键盘输入或从文件读入的形如:“constcount=10,sum=81.5,char1=’f’,string1=”hj”,max=169;”的常量说明串进行处理,分析常量说明串中各常量名、常量类型及常量值,并统计各种类型常量个数。三、实验要求1、输入的常量说明串,要求最后以分号作结束标志;2、根据输入串或读入的文本文件

2、中第一个单词是否为“const”判断输入串或文本文件是否为常量说明内容;3、识别输入串或打开的文本文件中的常量名。常量名必须是标识符,定义为字母开头,后跟若干个字母,数字或下划线;4、根据各常量名紧跟等号“=”后面的内容判断常量的类型。其中:字符型常量定义为放在单引号内的一个字符;字符串常量定义为放在双引号内所有内容;整型常量定义为带或不带+、-号,不以0开头的若干数字的组合;实型常量定义为带或不带+、-号,不以0开头的若干数字加上小数点再后跟若干数字的组合;5、统计并输出串或文件中包含的各种类型的常量个数;6、以二元组(类型,值)的形式输出各常量的类型和值;7

3、、根据常量说明串置于高级语言源程序中时可能出现的错误情况,模仿高级语言编译器对不同错误情况做出相应处理。四、运行结果1、输入如下正确的常量说明串:constcount=10,sum=81.5,char1=‘f’,max=169,str1=“h*542..4S!AAsj”,char2=‘@’,str2=“aa!+h”;输出:count(integer,10)sum(float,81.5)char1(char,‘f’)max(integer,169)str1(string,“h*542..4S!AAsj”)char2(char,‘@’)str2(string,“aa

4、!+h”)int_num=2;char_num=2;string_num=2;float_num=1.2、输入类似如下的保留字const错误的常量说明串:Aconsttcount=10,sum=81.5,char1=‘f’;输出类似下面的错误提示信息:Itisnotaconstantdeclarationstatement!Pleaseinputastringagain!3、输入类似如下含常量名或常量值错误的常量说明串:constcount=10,12sum=81.5,char1=‘ff’,max=0016;输出类似下面的错误提示信息:count(integer

5、,10)12sum(Wrong!Itisnotaidentifier!)char1(Wrong!Therearemorethanonecharin‘’.)max(Wrong!Theintegercan’tbestartedwith‘0’.)int_num=1;char_num=0;string_num=0;float_num=0.4、其他类型的错误处理情况(略)。五、提示本实验重点有三个:一是作为常量名的标识符的识别;二是如何根据“=”后出现的内容来判断常量类型;三是对各种错误的处理。难点是对整型和实型常量的判断必须综合考虑多种可能情况。建议:1、用指针或数组与

6、指针相结合来处理输入的常量说明串;2、对整型和实型常量处理时,重点考虑常数中‘0’的位置。六、分析与讨论1、若考虑用E或e的科学计数法来表示整数和实数,应该如何实现?2、若考虑布尔型常量,且规定其值只能为true或false,应该如何实现?3、如何对手工构造的词法分析程序做进一步的优化,以提高代码质量和运行效率?七.代码#include"stdio.h"#include"ctype.h"#include#include#include#defineN80#defineM16char*p0,*t0,*p

7、1,*t1,*p2,*str,*p3,*t3="const",*digi,*flo;charcha;intci=0,cf=0,cc=0,cs=0;voidmain(){voidmeasurefw();voidmeasure_iden();voidmeasure_str();voidmeasure_digit();voidmeasure_cha();printf("Inputstring:");p0=(char*)malloc(N*sizeof(char));p1=(char*)malloc(M*sizeof(char));p2=(char*)malloc

8、(M*sizeof(ch

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

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

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