编译原理实验报告-设计词法分析器.doc





《编译原理实验报告-设计词法分析器.doc》由会员分享,可在线阅读,更多相关《编译原理实验报告-设计词法分析器.doc(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、实 验 报 告 填写时间: 2014.4.25课程名称编译原理实验名称设计词法分析器姓名学号专业年级一、 实验目的: 设计并实现一个小型程序语言的词法分析器,实现源程序的输入,预处理词法分析,最后以编译程序需要的内部表示形式将识别的单词、符号、数字等关键字输出。二、 实验内容:设计词法分析器,定义关键字,待程序运行,输入待分析的程序段或程序的路径及名称,即可进行词法分析。三、 实验步骤:1. 在Microsoft Visual C+ 6.0中新建源文件;2. 编写头文件及类函数;3. 定义关键字;4. 关键字、字母、数字判断;5. 编写词法分析代码;6. 编写主函数;7. 新建待分析程序段,记
2、住其路径及名称;8. 运行此分析程序;9. 输入待分析的程序段的路径及名称。四、 实验结果与结论:(核心代码和程序的运行效果)核心代码1:String key15=begin,end,if,then,else,while,write,read,do, call,const,char,until,procedure,repeat; /关键字定义核心代码2:int Iskey(string c) /关键字判断 int i; for(i=0;iMAX;i+) if(pare(c)=0) return 1; return 0;int IsLetter(char c) /判断是否为字母 if(c=a)|
3、(c=A) return 1; else return 0;int IsDigit(char c) /判断是否为数字 if(c=0&c=9) return 1; else return 0;核心代码3:void analyse(FILE *fpin) /词法分析 string arr=; while(ch=fgetc(fpin)!=EOF) arr=; if(ch= |ch=t|ch=n) else if(IsLetter(ch) while(IsLetter(ch)|IsDigit(ch) if(ch=A) ch=ch+32; arr=arr+ch; ch=fgetc(fpin); fsee
4、k(fpin,-1L,SEEK_CUR); if (arr=key0)coutarrt8 $关键字endl; else if (arr=key1)coutarrt9 $关键字endl; else if (arr=key2)coutarrt3 $关键字endl; else if (arr=key3)coutarrt4 $关键字endl; else if (arr=key4)coutarrt5 $关键字endl; else if (arr=key5)coutarrt6 $关键字endl; else if (arr=key6)coutarrt7 $关键字endl; else if (arr=key7
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译 原理 实验 报告 设计 词法 分析器

限制150内