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

上传人:飞****2 文档编号:51843770 上传时间:2022-10-20 格式:DOC 页数:6 大小:4.34MB
返回 下载 相关 举报
编译原理实验报告-设计词法分析器.doc_第1页
第1页 / 共6页
编译原理实验报告-设计词法分析器.doc_第2页
第2页 / 共6页
点击查看更多>>
资源描述

《编译原理实验报告-设计词法分析器.doc》由会员分享,可在线阅读,更多相关《编译原理实验报告-设计词法分析器.doc(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

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

5、)coutarrt10 $关键字endl; else if (arr=key8)coutarrt11 $关键字endl; else if (arr=key9)coutarrt12 $关键字endl; else if (arr=key10)coutarrt13 $关键字endl; else if (arr=key11)coutarrt14 $关键字endl; else if (arr=key12)coutarrt15 $关键字endl; else if (arr=key13)coutarrt16 $关键字endl; else if (arr=key14)coutarrt17 $关键字endl;

6、else coutarrt0 $普通标识符endl; else if(IsDigit(ch) while(IsDigit(ch)|ch=.&IsDigit(fgetc(fpin) arr=arr+ch; ch=fgetc(fpin); fseek(fpin,-1L,SEEK_CUR); coutarrt2 $无符号实数endl; else switch(ch) case+ :coutcht31 $运算符endl;break; case- :coutcht32 $运算符endl;break; case* :coutcht33 $运算符endl;break; case= :coutcht37 $运

7、算符endl;break; case/ :coutcht34 $运算符endl;break; case( :coutcht52 $界符endl;break; case) :coutcht53 $界符endl;break; case :coutcht55 $界符endl;break; case :coutcht56 $界符endl;break; case; :coutcht54 $界符endl;break; case. :coutcht57 $界符endl;break; case, :coutcht58 $界符endl;break; case :coutcht59 $界符endl;break;

8、case :coutcht60 $界符endl;break; case: :ch=fgetc(fpin); if(ch=) cout:=t51 $运算符endl; else cout=t37 $运算符 :ch=fgetc(fpin); if(ch=) cout=t63 $运算符)coutt61 $输入控制符endl; else coutt62 $运算符endl; fseek(fpin,-1L,SEEK_CUR); break; case :ch=fgetc(fpin); if(ch=)cout=t64 $运算符endl; else if(ch=)coutt65 $输出控制符) coutt66 $运算符endl; elsecoutt67 $运算符endl; fseek(fpin,-1L,SEEK_CUR); break; default : coutcht100 $无法识别字符endl; 运行结果1:运行结果2:五、 实验中遇到的问题及解决办法:问题一:词法分析程序识别的关键字太少解决:在定义关键字时,多定义一些关键字,可以让程序分析的更为准确。问题二:运行程序时,每次需输入程序段,太繁琐;解决:添加代码,让程序读取文件中的程序段。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁