




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验一 简单词法分析程序设计一、实验目的了解词法分析程序的基本构造原理,掌握词法分析程序的手工构造方法。二、实验内容1、了解编译程序的词法分析过程。2、根据PASCAL语言的说明语句形式,用手工方法构造一个对说明语句进行词法分析的程序。该程序能对从键盘输入或从文件读入的形如:“const count=10,sum=81.5,char1=f,string1=”hj”, max=169;”的常量说明串进行处理,分析常量说明串中各常量名、常量类型及常量值,并统计各种类型常量个数。三、实验要求1、输入的常量说明串,要求最后以分号作结束标志;2、根据输入串或读入的文本文件中第一个单词是否为“const”判断输入串或文本文件是否为常量说明内容;3、识别输入串或打开的文本文件中的常量名。常量名必须是标识符,定义为字母开头,后跟若干个字母,数字或下划线;4、根据各常量名紧跟等号“=”后面的内容判断常量的类型。其中:字符型常量定义为放在单引号内的一个字符;字符串常量定义为放在双引号内所有内容;整型常量定义为带或不带+、- 号,不以0开头的若干数字的组合;实型常量定义为带或不带+、- 号,不以0开头的若干数字加上小数点再后跟若干数字的组合;5、统计并输出串或文件中包含的各种类型的常量个数;6、以二元组(类型,值)的形式输出各常量的类型和值;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”)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)12sum(Wrong! It is not a identifier!)char1(Wrong! There are more than one char in .)max(Wrong! The integer cant be started with 0.)int_num=1; char_num=0; string_num=0; float_num=0.4、其他类型的错误处理情况(略)。五、提示本实验重点有三个:一是作为常量名的标识符的识别;二是如何根据“=”后出现的内容来判断常量类型;三是对各种错误的处理。难点是对整型和实型常量的判断必须综合考虑多种可能情况。建议:1、用指针或数组与指针相结合来处理输入的常量说明串;2、对整型和实型常量处理时,重点考虑常数中0的位置。六、分析与讨论1、若考虑用E或e的科学计数法来表示整数和实数,应该如何实现?2、若考虑布尔型常量,且规定其值只能为true或false,应该如何实现?3、如何对手工构造的词法分析程序做进一步的优化,以提高代码质量和运行效率?七代码#includestdio.h#includectype.h#include#include#include#define N 80#define M 16char *p0,*t0,*p1,*t1, *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);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); 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; string_num=%d; float_num=%d.n,ci,cc,cs,cf);void measurefw()while(*p0!= ) /* 检查输入串是否以const开头 */if(*p0=*t3)p0+;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=*p0;p0+;p1+;*p1=0;/printf(%sn,p0);p0+;printf(%s,t1);void measure_str()str=p2;while(*(p0)!=)*p2=*p0;if(*(p0)=;)/丢了个分号,直接输出String data is 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+;pri
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 作业布置创建鼠标点击交互脚本16课件
- 二零二五年度国际贸易风险管理合同范本
- 二零二五年度商业地产锅炉供暖设施租赁经营协议
- 水电厂电工基础知识培训课件
- 二零二五年瓷砖材料品质保障采购协议
- 二零二五年度民宿改造与运营管理合同
- 2025版房地产项目营销手续代办服务合同范本
- 二零二五年度房地产项目绿色生态社区建设委托管理合同
- 二零二五版房地产项目投资咨询服务合同
- 2025版木门品牌授权与区域代理销售合同
- (新)部编人教版高中历史中外历史纲要上册《第13课-从明朝建立到清军入关课件》讲解教学课件
- 医药行业专题报告:VCTE技术(福瑞股份子公司)专利概览
- GB/T 42430-2023血液、尿液中乙醇、甲醇、正丙醇、丙酮、异丙醇和正丁醇检验
- 关于规范学校中层及以上领导干部岗位设置及任免办法
- 《现代汉语》课件修辞
- 某园区综合运营平台项目建议书
- 创造适合教育(2017年0613)
- 微创外科课件
- 易驱ED3000系列变频器说明书
- 农机行政处罚流程图
- GB∕T 6818-2019 工业用辛醇(2-乙基己醇)
评论
0/150
提交评论