TEST语言词法分析器.doc_第1页
TEST语言词法分析器.doc_第2页
TEST语言词法分析器.doc_第3页
TEST语言词法分析器.doc_第4页
TEST语言词法分析器.doc_第5页
已阅读5页,还剩3页未读 继续免费阅读

下载本文档

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

文档简介

实验一 TEST语言词法分析器一、 实验目的熟悉词法分析程序的设计方法。二、 实验内容1、 在windows的VC环境下,编写TEST语言的词法分析程序;2、 修改附录B的词法分析程序,添加保留字do、双分界符和|以及单分界符!的处理。三、 设计思想 算法的基本任务是从源程序中识别出具有独立意义的单词符号,其基本思想是根据扫描到单词符号的第一个字符的种类,分析与代码中相应的单词符号。四、 源程序#includestdio.h#includestring.h#includectype.h#define keyword 8char *keykeyword=if,int,for,while,do,return,break,continue;#define yunsuan 9char yunyunsuan=+-*/=!;#define fenge 8char fenfenge=,.;();char ch;int i,k;char buff20;void output(int ,char*);void scan(FILE *fp) int j; ch=fgetc(fp); while(ch= |ch=n|ch=t) ch=fgetc(fp); if(isalpha(ch) /*输入的是字母,进行 标识符处理*/ buff0=ch; i=1; ch=fgetc(fp); while(isalnum(ch) /*如果是字母数字则组合,否则结束*/ buffi=ch; i+; ch=fgetc(fp); buffi=0; /*查找保留字*/ fseek(fp,-1,1); j=0; while(jkeyword) strcmp(buff,keyj) j+; if(j=keyword) output(2,buff); else output(1,buff); else if(isdigit(ch) buff0=ch; ch=fgetc(fp); i=1; while(isdigit(ch) /*如果是数字则整合数字*/ buffi=ch; i+; ch=fgetc(fp); buffi=0; /*整数整合结束*/ fseek(fp,-1,1); output(3,buff); else if(strchr(fen,ch)0) /*判断分隔符*/ buff0=ch; ch=fgetc(fp); buff1=0; fseek(fp,-1,1); output(5,buff);else if(strchr(yun,ch)0) /*判断运算符*/ buff0=ch; if(ch=) /*双运算符*/ ch=fgetc(fp); if(ch=) output(4,=); else fseek(fp,-1,1); output(4,=); else if(ch=) ch=fgetc(fp); if(ch=) output(4,=); else fseek(fp,-1,1); output(4,); else if(ch=) ch=fgetc(fp); if(ch=) output(4,=); else fseek(fp,-1,1); output(4,); else if(ch=!) ch=fgetc(fp); if(ch=) output(4,!=); else fseek(fp,-1,1); output(0,error!); else ch=fgetc(fp); buff1=0; fseek(fp,-1,1); output(4,buff);else /*无法识别的字符*/ buff0=ch; buff1=0; ch=fgetc(fp); fseek(fp,-1,1); printf(t非法字符%sn,buff);void save()FILE *out; out=fopen(out.txt,w+); while (gets(buff) fprintf(out,%sn,ch); fclose(out);void output(int n,char *m) /*输出格式*/ printf( %-2d , %-8sn,n,m);void main()FILE *fp; char filename20;printf(数据类型定义规则:n); printf(保留字-1 标识符-2 常数-3 运算符-4 分隔符-5n); printf(Type the file name which you want to open:); scanf(%s,filename); fp=fopen(filename,r); /*以只读方式打开指定文件*/ if(fp=fopen(filename,r)=NULL) /*文件不存在输出错误*/ printf(File does not exist!check it again); else printf( 种别码 , 值 n); while(ch!=EOF) scan(fp); printf(The analysis is ov

温馨提示

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

评论

0/150

提交评论