![TEST语言词法分析器.doc_第1页](http://file.renrendoc.com/FileRoot1/2019-11/17/8a8d8548-7d38-45c6-8d77-f63abd8a2c03/8a8d8548-7d38-45c6-8d77-f63abd8a2c031.gif)
![TEST语言词法分析器.doc_第2页](http://file.renrendoc.com/FileRoot1/2019-11/17/8a8d8548-7d38-45c6-8d77-f63abd8a2c03/8a8d8548-7d38-45c6-8d77-f63abd8a2c032.gif)
![TEST语言词法分析器.doc_第3页](http://file.renrendoc.com/FileRoot1/2019-11/17/8a8d8548-7d38-45c6-8d77-f63abd8a2c03/8a8d8548-7d38-45c6-8d77-f63abd8a2c033.gif)
![TEST语言词法分析器.doc_第4页](http://file.renrendoc.com/FileRoot1/2019-11/17/8a8d8548-7d38-45c6-8d77-f63abd8a2c03/8a8d8548-7d38-45c6-8d77-f63abd8a2c034.gif)
![TEST语言词法分析器.doc_第5页](http://file.renrendoc.com/FileRoot1/2019-11/17/8a8d8548-7d38-45c6-8d77-f63abd8a2c03/8a8d8548-7d38-45c6-8d77-f63abd8a2c035.gif)
已阅读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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 计算机实习心得
- 《光纤到户用多电信业务经营者共用型配线设施 第2部分:光纤配线架GBT 39564.2-2020》详细解读
- 以预防为先导的健康照顾
- 预防保健科年终总结与计划
- 幼儿园预防佝偻病的课件
- 中国心血管一级预防指南解读
- 万科合同范本
- 智能制造装备单元系统集成 课件项目二 智能制造单元虚拟仿真
- 2024年天翼云从业者认证考试题库(判断题)
- 中学生读书的演讲稿
- 矿山勘探工作规程手册
- 人教版高中数学《对数的概念》优秀说课课件
- 数字逻辑课程设计定时器
- 国家开放大学电大实用法律基础形考任务1-4答案
- 2023年民营企业500强名单
- 四年级下册数学练习二十公开课教案教学设计课件公开课教案教学设计课件公开课教案课件
- 【中考真题】2021年江西省中考地理试卷(附答案)
- 医院药物(医疗器械)临床试验经费管理办法
- 纵隔占位麻醉的临床思维课件
- 2021译林版高中英语选择性必修二课文翻译
- 小学四五六年级科学暑假作业(动手实践部分)
评论
0/150
提交评论