编译原理实验报告词法分析器语法分析器.doc
《编译原理实验报告词法分析器语法分析器.doc》由会员分享,可在线阅读,更多相关《编译原理实验报告词法分析器语法分析器.doc(11页珍藏版)》请在课桌文档上搜索。
1、-编译原理实验报告实验一一、实验名称:词法分析器的设计二、实验目的:1,词法分析器能够识别简单语言的单词符号 2,识别出并输出简单语言的基本字.标示符.无符号整数.运算符.和界符。三、实验要求:给出一个简单语言单词符号的种别编码词法分析器四、实验原理:1、词法分析程序的算法思想算法的基本任务是从字符串表示的源程序中识别出具有独立意义的单词符号,其基本思想是根据扫描到单词符号的第一个字符的种类,拼出相应的单词符号。2、程序流程图(1)主程序输入要分析的语句调用扫描、分析程序输出单词符号二元组结束判断读入字符是否为#”(2)扫描子程序Token清空当前字符=?标示符常数表中查找结束 Error()
2、输出二元式基本字用户标示符结束Get()3、各种单词符号对应的种别码单词符号种别码助记符码值while1while-if2if-else3else-switch4switch-case5case-标识符6idid在符号表中的位置常数7numnum在常数表中的位置+8+-9-*10*-=11relopLE11relopLT=11relopEQ=12=-;13;-五、实验容:1、实验分析编写程序时,先定义几个全局变量a、token(均为字符串数组),c,s( char型),i,j,k(int型),a用来存放输入的字符串,token另一个则用来帮助识别单词符号,s用来表示正在分析的字符。字符串输入之
3、后,逐个分析输入字符,判断其是否#,若是表示字符串输入分析完毕,结束分析程序,若否则通过int digit(char c)、int letter(char c)判断其是数字,字符还是算术符,分别为用以判断数字或字符的情况,算术符的判断可以在switch语句中进行,还要通过函数int lookup(char token)来判断标识符和保留字。2 实验词法分析器源程序:#include #include #include int i,j,k;char c,s,a20,token20=0;int letter(char s)if(s=97)&(s=48)&(s=57) return(1);else
4、return(0);void get()s=ai;i=i+1;void retract()i=i-1;int lookup(char token20)if(strcmp(token,while)=0) return(1);else if(strcmp(token,if)=0) return(2);else if(strcmp(token,else)=0) return(3);else if(strcmp(token,switch)=0) return(4);else if(strcmp(token,case)=0) return(5);else return(0);void main()pri
5、ntf(please input string :n);i=0; doi=i+1;scanf(%c,&ai);while(ai!=#);i=1;j=0;get();while(s!=#) memset(token,0,20);switch(s)case a:case b: case c:case d:case e:case f:case g:case h:case i:case j:case k:case l:case m:case n:case o:case p:case q:case r:case s:case t:case u:case v:case w:case *:case y:ca
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译 原理 实验 报告 词法 分析器 语法
链接地址:https://www.desk33.com/p-8150.html