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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

简单词法分析程序设计.docx

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

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

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

4、r2(string, “ aa!+h ” )int_num=2; char_num=2; string_num=2; float_num=1.2、输入类似如下的保留字 const 错误的常量说明串:Aconstt count=10,sum=81.5,char1= f ;输出类似下面的错误提示信息:It is not a constant declaration statement!Please input a string again!3、输入类似如下含常量名或常量值错误的常量说明串:const count=10,12sum=81.5,char1= ff ,max=0016;输出类似下面的错误

5、提示信息:count(integer,10)12sum(Wrong! It is not a identifier!) char1(Wrong! There are more than one char in .)max(Wrong! The integer can t be started with 0.)int_num=1; char_num=0; string_num=0; float_num=0.4、其他类型的错误处理情况(略) 。五、提示本实验重点有三个:一是作为常量名的标识符的识别;二是如何根据“ =”后出现的内容来判断常量类型;三是对各种错误的处理。难点是对整型和实型常量的判断必

6、须综 合考虑多种可能情况。建议: 1、用指针或数组与指针相结合来处理输入的常量说明串; 2、对整型和实型常量处理时,重点考虑常数中 0的位置。六、分析与讨论1、若考虑用 E 或 e 的科学计数法来表示整数和实数,应该如何实现? 2、若考虑布尔型常量,且规定其值只能为 true 或 false ,应该如何实现?3、如何对手工构造的词法分析程序做进一步的优化,以提高代码质量和运行效率?七代码#includestdio.h #includectype.h #include #include #include #define N 80 #define M 16 char *p0,*t0,*p1,*t1

7、, *p2,*str,*p3,*t3=const,*digi,*flo;char cha;int ci=0,cf=0,cc=0,cs=0;void main()void measurefw();void measure_iden();void measure_str();void measure_digit();void measure_cha();printf(nInput string: n);p0=(char *)malloc(N*sizeof(char);p1=(char *)malloc(M*sizeof(char);p2=(char *)malloc(M*sizeof(char);

8、p3=(char *)malloc(M*sizeof(char);gets(p0);printf(n);measurefw();/* 开始处理输入串 p0 */while(*(p0)= |*(p0)=,) /* 从串 p0 中取标识符,并将 其作为常量名存放到串 p1 中 */p0+;if(*(p0)= |*(p0)=,)continue;elsemeasure_iden(); /*p0=if(!isdigit(*p0)&*p0!=&*p0!=)/ 注意 和 做字符表示时用 和system(cls); printf(n Const data is wrong . Exit !);exit(0)

9、;else if(*p0=) /*p0+;measure_str();else if(isdigit(*p0) /*measure_digit();else if(*p0=) /处理字符串常量 */处理数字 */处理字符常量p0+; measure_cha();if(*p0!=;)system(cls);printf(n This centence is wrong . Exit !); exit(0);elseprintf(int_num=%d; char_num=%d; float_num=%d.n,ci,cc,cs,cf);string_num=%d;void measurefw()wh

10、ile(*p0!= ) /*if(*p0=*t3)p0+;检查输入串是否以 const开头 */t3+;elsesystem(cls);printf(nThis string isnt a const declaration!); exit(0);/ printf(This string is a const declaration!n);void measure_iden()if (*p0!=_&(!isalpha(*p0)system(cls);printf(n Const name is wrong . Exit !); exit(0);else if (*p0=_|isalpha(*p

11、0)t1=p1;while(*p0!=)*p1=*p0;p0+;p1+;*p1=0;/ printf(%sn,p0);p0+;printf(%s,t1);void measure_str()str=p2;while(*(p0)!=) 丢了个分号,直接输出 String data is*p2=*p0;if(*(p0)=;)/ wrong. Exitsystem(cls);printf(n String data is wrong. Exit !); exit(0);p0+;p2+;*p2=0;p0+;cs+;printf(string,%s)n,str);void measure_digit()

12、char *jud;int mark=0;jud=p0;for(;*(jud)!=,&*(jud)!=;jud+)if(*jud=.)mark=1;break;if(mark=0)digi=p2;while(*p0!=,&*p0!=;)*p2=*p0;p0+;p2+;*p2=0;ci+;printf(integer,%s)n,digi);if(mark=1)flo=p2;while(*p0!=,&*p0!=;)*p2=*p0;p0+;p2+; *p2=0; cf+;printf(float,%s)n,flo);void measure_cha()char *jud;jud=p0;if(*(jud+1)=&*(jud)!=) cha=*p0;p0=p0+2;cc+;elsesystem(cls);printf(n char data is wrong. Exit !); exit(0);printf(char,%c)n,cha);

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2