《2022年编译实验报告方案词法分析器 .pdf》由会员分享,可在线阅读,更多相关《2022年编译实验报告方案词法分析器 .pdf(6页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、个人资料整理仅限学习使用实 验 报 告填写时间: 2018.4.25 课程名称编译原理实验名称设计词法分析器姓名学号专业年级一、 实验目的:设计并实现一个小型程序语言的词法分析器,实现源程序的输入,预处理词法分析,最后以编译程序需要的内部表示形式将识别的单词、符号、数字等关键字输出。二、 实验内容:设计词法分析器,定义关键字,待程序运行,输入待分析的程序段或程序的路径及名称,即可进行词法分析。三、 实验步骤:1. 在 Microsoft Visual C+ 6.0 中新建源文件;2. 编写头文件及类函数;3. 定义关键字;4. 关键字、字母、数字判断;5. 编写词法分析代码;6. 编写主函数;
2、7. 新建待分析程序段,记住其路径及名称;8. 运行此分析程序;9. 输入待分析的程序段的路径及名称。四、 实验结果与结论: / 关键字判断 int i。 for(i=0。i if(pare(c=0 return 1。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 1 页,共 6 页个人资料整理仅限学习使用 return 0。 int IsLetter(char c / 判断是否为字母 if(c&(c=a|(c&(c=A return 1。 else return 0。 int IsDigit(char c / 判断是否为数字 if(c=0&c r
3、eturn 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&(ch=A ch=ch+32。 arr=arr+ch。 ch=fgetc(fpin。 fseek(fpin,-1L,SEEK_CUR。 if (arr=key0coutarrt8 $关键字 coutarrt9 $关 键 字coutarrt3
4、$关 键 字coutarrt4 $关 键 字coutarrt5 $关 键 字coutarrt6 $关 键 字coutarrt7 $关 键 字coutarrt10 $关 键 字coutarrt11 $关 键 字coutarrt12 $关 键 字精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 2 页,共 6 页个人资料整理仅限学习使用coutarrt13 $ 关键 字coutarrt14 $ 关键 字coutarrt15 $ 关键 字coutarrt16 $ 关键 字coutarrt17 $ 关键 字endl 。 else coutarrt0 $普通标
5、识符 while(IsDigit(ch|ch=.&IsDigit(fgetc(fpin arr=arr+ch。 ch=fgetc(fpin。 fseek(fpin,-1L,SEEK_CUR。 coutarrt2 $无符号实数 case+ :coutcht31 $运算符endl 。break 。 case- :coutcht32 $运算符endl 。break 。 case* :coutcht33 $运算符endl 。break 。 case= :coutcht37 $运算符endl 。break 。 case/ :coutcht34 $运算符endl 。break 。 case( :coutc
6、ht52 $界符 :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。 case :coutcht60 $界符。 if(ch= cout:=t51 $运算符 endl 。 else cout=t37 $运算符
7、。 break。 case :ch=fgetc(fpin。 if(ch= cout=t63 $运算符 coutt61 $输入控制符 endl 。 else coutt62 $运算符 。 break。 case。 if(ch=cout=t64 $运算符 endl 。 else if(ch=coutt65 $ 输 出 控 制 符 coutt66 $ 运 算 符endl 。 elsecoutt67 $运算符 。 break。 default : coutcht100 $无法识别字符 endl 。 运行结果 1:运行结果 2:精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 4 页,共 6 页个人资料整理仅限学习使用五、 实验中遇到的问题及解决办法:问题一:词法分析程序识别的关键字太少解决:在定义关键字时,多定义一些关键字,可以让程序分析的更为准确。问题二:运行程序时,每次需输入程序段,太繁琐;解决:添加代码,让程序读取文件中的程序段。精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 5 页,共 6 页个人资料整理仅限学习使用精选学习资料 - - - - - - - - - 名师归纳总结 - - - - - - -第 6 页,共 6 页
限制150内