2022年编译实验报告方案词法分析器.docx
精选学习资料 - - - - - - - - - 个人资料整理 仅限学习使用实 验 报 告 填写时间: 2022.4.25 课程名称学号专业年级编译原理试验名称设计词法分析器姓名一、 试验目的:设计并实现一个小型程序语言的词法分析器,实现源程序的输入,预处理词法分析,最终以编译程序需要的内部表示形式将识别的单词、符号、数 字等关键字输出;二、 试验内容:设计词法分析器,定义关键字,待程序运行,输入待分析的程序段或程序的路径及名称,即可进行词法分析;三、 试验步骤:1. 在 Microsoft Visual C+ 6.0 中新建源文件;2. 编写头文件及类函数;3. 定义关键字;4. 关键字、字母、数字判定;5. 编写词法分析代码;6. 编写主函数;7. 新建待分析程序段,记住其路径及名称;8. 运行此分析程序;9. 输入待分析的程序段的路径及名称;四、 试验结果与结论: <核心代码和程序的运行成效)核心代码 1:Stringkey15="begin","end","if","then","else","while","write","read","do", "call","const","char","until","procedure","repeat"核心代码 2:;/ 关键字定义名师归纳总结 int Iskeystring c> / 关键字判定第 1 页,共 6 页 int i; fori=0;i<MAX;i+> ifkeyi.comparec>=0> return 1;- - - - - - -精选学习资料 - - - - - - - - - ;个人资料整理仅限学习使用 return 0 int IsLetterchar c> / 判定是否为字母; ifc<='z'>&&c>='a'>>|c<='Z'>&&c>='A'>>> return 1 else return 0; int IsDigitchar c> / 判定是否为数字 ifc>='0'&&c<='9'> return 1; else return 0; 核心代码 3: void analyseFILE *fpin> / 词法分析 string arr=""; whilech=fgetcfpin>>.=EOF> arr=""; ifch=' '|ch='t'|ch='n'> else ifIsLetterch>> whileIsLetterch>|IsDigitch>> ifch<='Z'>&&ch>='A'>> ch=ch+32; arr=arr+ch; ch=fgetcfpin>; fseekfpin,-1L,SEEK_CUR>; if arr=key0>cout<<arr<<"t8 $ 关键字 "<<endl ; else if arr=key1>cout<<arr<<"t9 $ 关 键 字 "<<endl ; "<<endl ; else if arr=key2>cout<<arr<<"t3 $ 关 键 字 else if arr=key3>cout<<arr<<"t4 $ 关 键 字"<<endl ; else if arr=key4>cout<<arr<<"t5 $ 关 键 字"<<endl ; else if arr=key5>cout<<arr<<"t6 $ 关 键 字"<<endl ; else if arr=key6>cout<<arr<<"t7 $ 关 键 字"<<endl ; "<<endl ; else if arr=key7>cout<<arr<<"t10 $ 关 键 字 else if arr=key8>cout<<arr<<"t11 $ 关 键 字"<<endl ; 名师归纳总结 else if arr=key9>cout<<arr<<"t12 $ 关 键 字第 2 页,共 6 页- - - - - - -精选学习资料 - - - - - - - - - "<<endl ; else if 个人资料整理仅限学习使用 $ 关键 字arr=key10>cout<<arr<<"t13 "<<endl ; "<<endl ; else if arr=key11>cout<<arr<<"t14 $ 关键 字"<<endl ; else if arr=key12>cout<<arr<<"t15 $ 关键 字 else if arr=key13>cout<<arr<<"t16 $ 关键 字"<<endl ; else if arr=key14>cout<<arr<<"t17 $ 关键 字"<<endl ; else cout<<arr<<"t0 $ else ifIsDigitch>> 一般标识符 "<<endl ; whileIsDigitch>|ch='.'&&IsDigitfgetcfpin>>> arr=arr+ch; ch=fgetcfpin> fseekfpin,-1L,SEEK_CUR>; cout<<arr<<"t2 $无符号实数 "<<endl ; else switchch> case'+' :cout<<ch<<"t31 $ case'-' :cout<<ch<<"t32 $ case'*' :cout<<ch<<"t33 $ case'=' :cout<<ch<<"t37 $ case'/' :cout<<ch<<"t34 $ case'' :cout<<ch<<"t52 $ case'>' :cout<<ch<<"t53 $ case'' :cout<<ch<<"t55 $ case'' :cout<<ch<<"t56 $运算符 "<<endl ;break ;运算符 "<<endl ;break ;运算符 "<<endl ;break ;运算符 "<<endl ;break ;运算符 "<<endl ;break ;界符"<<endl ;break ;界符"<<endl ;break ;界符"<<endl ;break ;界符"<<endl ;break ; case';' :cout<<ch<<"t54 $界符 "<<endl ;break ; case'.' :cout<<ch<<"t57 $ case',' :cout<<ch<<"t58 $ case'' :cout<<ch<<"t59 $ case'' :cout<<ch<<"t60 $界符"<<endl ;break ;界符"<<endl ;break ;界符"<<endl ;break ;界符"<<endl ;break ; case':' :ch=fgetcfpin>; ifch='='> cout<<":="<<"t51 $ else cout<<"="<<"t37 $运算符 "<<endl ;运算符 "<<endl ; fseekfpin,-1L,SEEK_CUR>; break; case'>' :ch=fgetcfpin> ifch='='> cout<<">="<<"t63 $运算符 "<<endl ;名师归纳总结 - - - - - - -第 3 页,共 6 页精选学习资料 - - - - - - - - - 个人资料整理 仅限学习使用 ifch='>'>cout<<">>"<<"t61 $ else cout<<">"<<"t62 $输入掌握符 "<<endl ;运算符 "<<endl ; fseekfpin,-1L,SEEK_CUR>; break; case'<' :ch=fgetcfpin> ifch='='>cout<<"<="<<"t64 $运算符 "<<endl ;"<<endl ; else ifch='<'>cout<<"<<"<<"t65 $ 输 出 控 制 符 else ifch='>'> cout<<"<>"<<"t66 $ 运 算 符"<<endl ; elsecout<<"<"<<"t67 $运算符 "<<endl ; fseekfpin,-1L,SEEK_CUR>; break; 运行结果 1:运行结果 2:名师归纳总结 - - - - - - -第 4 页,共 6 页精选学习资料 - - - - - - - - - 个人资料整理 仅限学习使用五、 试验中遇到的问题及解决方法:问题一:词法分析程序识别的关键字太少 解决:在定义关键字时,多定义一些关键字,可以让程序分析的更为准 确;问题二:运行程序时,每次需输入程序段,太繁琐;解决:添加代码,让程序读取文件中的程序段;名师归纳总结 - - - - - - -第 5 页,共 6 页精选学习资料 - - - - - - - - - 名师归纳总结 个人资料整理仅限学习使用第 6 页,共 6 页- - - - - - -