




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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, )str2(string,“ aa!+h
4、” )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;输出类似下面的错误提示信息:count(integer,10
5、)12sum(Wrong! It is not a identifier!) char1(Wrong! There are more than one char in .)max(Wrong! The integer can t be started with0.)int_num=1; char_num=0; string_num=0; float_num=0.4、其他类型的错误处理情况(略) 。五、提示本实验重点有三个:一是作为常量名的标识符的识别;二是如何根据“=”后出现的内容来判断常量类型;三是对各种错误的处理。难点是对整型和实型常量的判断必须综 合考虑多种可能情况。建议: 1、用指针或
6、数组与指针相结合来处理输入的常量说明串;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, *p2,*str,*p3,*t3=const,
7、*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);p3=(char *)malloc(M*sizeo
8、f(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);else if(*p0=) /*p0+;measu
9、re_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()while(*p0!= ) /*if(*p0=*t3)p
10、0+;检查输入串是否以 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(*p0)t1=p1;while(*p0!=)*p1=*p
11、0;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()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+;p
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 年度跨行业名人演唱会策划执行服务协议
- 2025年度医疗机构员工心理辅导与健康管理服务合同
- 2025年校园文化改造与教育资源共享合同
- 2025年文化主题公园特色景点租赁合作意向书
- 2025年中级主管药师专业实践能力考试试题及答案解析
- 2025年药学(中级)职称「回忆版试题及答案」
- 血液科护理考试题及答案
- 2024年医疗器械培训试题(含答案)
- 2025年护理核心制度考试试题附答案
- 2025-2030中国离心泵行业员工培训体系构建与实施效果报告
- 身份证委托书
- 高血压的危害-课件
- 陕西水资源论证报告表
- ISO15189医学实验室认可概况课件
- 单选题51-100试题含答案
- 轻钢龙骨、双层石膏板吊顶施工方案
- 安全网(平网)张挂安全技术要求
- 危险品管理台帐
- 政务云收费标准 云托管收费标准
- 计算机辅助翻译实用教程ppt课件(完整版)
- 研学旅行概论教学课件汇总完整版电子教案
评论
0/150
提交评论