简单词法分析程序设计_第1页
简单词法分析程序设计_第2页
简单词法分析程序设计_第3页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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,'

4、)str2(string,“aa!+h )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

5、 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、如何对手工构造的词法分析程序做进一步的优化,以提高代码质量和运行效率?七代码#include"stdio.h" #include"ctype.h" #include<stdlib.h> #include<string.h>#include<win

7、dows.h> #define N 80 #define M 16 char *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(

8、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)=',')cont

9、inue;else注意 ' 和" 做字measure_iden(); /*p0="=" if(!isdigit(*p0)&&*p0!='"'&&*p0!=''')/处理字符串常量*/处理数字*/符表示时用 ' 和 "system("cls"); printf("n Const data is wrong . Exit !");exit(0);else if(*p0='"') /*p0+;mea

10、sure_str();else if(isdigit(*p0) /*measure_digit();else if(*p0=''') /处理字符常p0+; measure_cha();string_num=%d;开头 */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,c

11、s,cf); void measurefw()while(*p0!=' ') /*检查输入串是否以"'constif(*p0=*t3)p0+;t3+;elsesystem("cls");printf("nThis string isn't a const declaration!"); exit(0);/ printf("This string is a const declaration!n");void measure_iden()if (*p0!='_'&&

12、;(!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)!='

13、"') 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(;*(

14、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 *

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论