欢迎来到冰豆网! | 帮助中心 分享价值,成长自我!
冰豆网
全部分类
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • 党团工作>
  • ImageVerifierCode 换一换
    首页 冰豆网 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    编译原理实验题目解析.docx

    • 资源ID:8928070       资源大小:26.36KB        全文页数:33页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    编译原理实验题目解析.docx

    1、编译原理实验题目解析编译原理课程设计指导书题目一 基于语法制导翻译的表达式转换编译器一、设计目的通过本课程设计获得对实际编译器的构造原理、过程和方法的感性认识,全面掌握语法制导翻译技术。二、设计内容采用语法制导翻译模式设计一个包含词法分析、语法分析、符号表管理、错误处理及输出等功能模块的、由中缀表达式到后缀表达式的完整编译器。该翻译器的规格说明如下:start list eoflist expr |expr expr + term print(+) | expr term print(-) | term|term term * factor print(*) | term / factor p

    2、rint(/) | term div factor print(DIV) | term mod factor print(MOD) factor ( expr )| id print( id.name ) | num print( num.value ) 三、设计要求1、使用模块化设计思想来设计该编译器;2、词法分析模块用于读入输入串,并将其转换成供语法分析模块使用的记号流。其中包括滤掉空格和注释、识别常数、识别标识符和关键字等功能;3、要求在语法分析模块中利用语法制导翻译技术完成具体的中缀表达式到后缀表达式的翻译,其中包括按前述翻译器的规格说明构建对应表达式、项、因子的非终结符expr、te

    3、rm和factor的函数以及检查记号是否匹配的函数;并在不匹配时调用错误处理模块;4、要求符号表管理模块主要完成符号表对应数据结构的具体实现功能;5、错误处理模块负责报告错误信息及位置,并终止分析过程;6、输出模块完成翻译后所得到的后缀表达式的输出。四、运行结果1、从键盘输入任意中缀表达式,如: 4 - 5 * 6 DIV 4 + 8 MOD 2输出相应的后缀表达式: 456*4DIV-82MOD+1、 若键盘输入串为非中缀表达式时,如: 4 !+* 5 - 6 DIV 4 + 8 MOD 2输出相应语法错误报告信息,并停止语法分析,如: line 1 : compiler error !五、

    4、提示1、将各功能模块设计为独立的源程序文件;2、建立一个全局头文件,将本设计所需要用到的系统头文件的打开、一些必要的宏定义和全局变量的声明信息放在该全局头文件中;3、将本设计所有文件加入一个工程文件。六、分析与讨论1、如何修改错误处理模块,使得编译器在发现错误后能跳过出错语句,继续进行语法分析;2、试使用手工构造和自动生成相结合的方法来完成本课程设计;3、仔细研读附录C有关“PL/0语言词法分析器的手工构造和自动生成”的设计内容,并通过借鉴PL/0语言词法分析器的设计方法和具体实现技术,对本课程设计的综合设计进行优化。题目二 说明语句的词法分析器一、设计目的了解的基本构造原理,掌握词法分析程序

    5、的手工构造及自动构造方法。二、设计内容根据PASCAL语言的说明语句形式,用手工及自动方法构造一个对说明语句进行词法分析的程序。该程序能对从键盘输入或从文件读入的形如:“const count=10,sum=81.5,char1=f,string1=”hj”, max=169;”的常量说明串进行处理,分析常量说明串中各常量名、常量类型及常量值,并统计各种类型常量个数。三、设计要求1、输入的常量说明串,要求最后以分号作结束标志;2、根据输入串或读入的文本文件中第一个单词是否为“const”判断输入串或文本文件是否为常量说明内容;3、识别输入串或打开的文本文件中的常量名。常量名必须是标识符,定义为

    6、字母开头,后跟若干个字母,数字或下划线;4、根据各常量名紧跟等号“=”后面的内容判断常量的类型。其中:字符型常量定义为放在单引号内的一个字符;字符串常量定义为放在双引号内所有内容;整型常量定义为带或不带+、- 号,不以0开头的若干数字的组合;实型常量定义为带或不带+、- 号,不以0开头的若干数字加上小数点再后跟若干数字的组合;5、统计并输出串或文件中包含的各种类型的常量个数;6、以二元组(类型,值)的形式输出各常量的类型和值;7、根据常量说明串置于高级语言源程序中时可能出现的错误情况,模仿高级语言编译器对不同错误情况做出相应处理。四、运行结果1、输入如下正确的常量说明串:const count

    7、=10,sum=81.5,char1=f,max=169,str1=“h*54 2.4S!AAsj”, char2=,str2=“aa!+h”;输出:count(integer,10)sum(float,81.5)char1(char, f)max(integer,169)str1(string,“h*54 2.4S!AAsj”)char2(char, )str2(string,“aa!+h”)int_num=2; char_num=2; string_num=2; float_num=1.2、输入类似如下的保留字const错误的常量说明串:Aconstt count=10,sum=81.5,

    8、char1=f;输出类似下面的错误提示信息:It is not a constant declaration statement! Please input a string again!3、输入类似如下含常量名或常量值错误的常量说明串:const count=10,12sum=81.5,char1=ff,max=0016;输出类似下面的错误提示信息:count(integer,10)12sum(Wrong! It is not a identifier!)char1(Wrong! There are more than one char in .)max(Wrong! The integer

    9、 cant be started with 0.)int_num=1; char_num=0; string_num=0; float_num=0.4、其他类型的错误处理情况(略)。五、提示本课程设计重点有三个:一是作为常量名的标识符的识别;二是如何根据“=”后出现的内容来判断常量类型;三是对各种错误的处理。难点是对整型和实型常量的判断必须综合考虑多种可能情况。提示:1、 用指针或数组与指针相结合来处理输入的常量说明串;2、 对整型和实型常量处理时,重点考虑常数中0的位置。六、分析与讨论1、若考虑用E或e的科学计数法来表示整数和实数,应该如何实现?2、若考虑布尔型常量,且规定其值只能为true

    10、或false,应该如何实现?3、如何对手工构造的词法分析程序做进一步的优化,以提高代码质量和运行效率?题目三 基于预测分析方法的表达式语法分析器一、设计目的了解预测分析器的基本构成及用自顶向下的预测法对表达式进行语法分析的方法,掌握预测语法分析程序的手工构造方法。二、设计内容已知文法GS:S-ATA-BUT-+AT|$U-*BU|$B-(S)|m其中,$表示空串。对该文法构造预测分析表,并手工构造预测分析程序,对输入串m+m*m#进行语法分析,并根据栈的变化状态输出分析过程。三、设计要求:1、判断上述文法GS是否LL(1)文法,若不是,将其转变为LL(1)文法;2、对转变后的LL(1)文法建立

    11、预测分析表;3、根据清华大学出版、吕映之等编著的编译原理教材教材第五章Page 88的图5.11手工构造预测分析程序;4、用预测分析程序对键盘输入串m+m*m#进行语法分析,并根据栈的变化状态输出给定串的具体分析过程。四、运行结果从键盘输入串:m+m*m#;输出:用预测分析法分析符号串m+m*m#的过程StepStackStringRuleStepStackStringRule1#Sm+m*m#S-AT10#TUmm*m#M匹配2#TAm+m*m#A-BU11#TU*m#U-*BU3#TUBm+m*m#B-m12#TUB*m#*匹配4#TUmm+m*m#M匹配13#TUBm#B-m5#TU+m

    12、*m#U-$14#TUmm#M匹配6#T+m*m#T-+AT15#TU#U-$7#TA+m*m#+匹配16#T#T-$8#TAm*m#A-BU17#接受9#TUBm*m#B-m五、提示本课程设计重点有两个:一是如何用适当的数据结构实现预测分析表存储和使用;二是如何实现各规则右部串的逆序入栈处理。建议:使用结构体数组。六、分析与讨论1、若输入串不是指定文法的句子,会出现什么情况?2、总结预测语法分析程序的设计和实现的一般方法。题目四 基于算符优先分析方法的表达式语法分析器一、设计目的了解用算符优先法对表达进行语法分析的方法,编程实现算符优先表达式语法分析器。二、设计内容对简单表达式文法构造算符优

    13、先分析器。三、设计要求1、对下列简单表达式文法G E构造算符优先关系表。E # E #E E + T | TT T * F | FF P / F PP ( E )i2、根据算符优先关系表,使用栈结构来实现算符优先分析:设置两个栈:存放运算符的OPTR栈和存放操作数或运算结果的OPND栈。具体算法描述如下:(1)首先置操作数OPND栈为空栈,将#入运算符OPTR栈。(2)依次读入表达式中每个单词,若是操作数则进OPND栈,若是运算符则转(3)。(3)当前设读入的运算符为2,查找算符优先关系表,比较2与OPTR栈顶元素1 :若1-*/(=i#=2、 参考严蔚敏等编著、清华大学出版社出版的C语言版数

    14、据结构P52-P54的表达式求值算法。题目五递归下降分析法一、设计目的掌握递归下降分析法的基本原理,掌握预测符集的求法, 掌握递归下降分析程序的构造方法。二、设计内容假设文法中有如下的产生式A1 | 2 | | n,则应按如下方法编写语法分析子程序procedure A() begin if tokenPredict(A1) then (1) else if tokenPredict(A2) then (2) else if tokenPredict(An) then (n) else error() end其中对i =X1X2Xn,(i) =(X1); (X2); (Xn); 如果XiVN,

    15、(Xi)= Xi 如果XiVT,(Xi)= Match(Xi) 如果Xi= , () = skip(空语句)三、设计要求:理解递归下降语法分析方法的主要原理,理解递归下降分析法对文法的要求, 熟练掌握Predict集合的求法, 熟练掌握文法变换算法(消除左递归和消除公共前缀)。四、提示:1. 基本原理递归下降法是语法分析中最易懂的一种方法。它的主要原理是,对每个非终极符按其产生式结构构造相应语法分析子程序,其中终极符产生匹配命令,而非终极符则产生过程调用命令。因为文法递归相应子程序也递归,所以称这种方法为递归子程序下降法或递归下降法。其中子程序的结构与产生式结构几乎是一致的。2. 文法要求递归

    16、下降法要满足的条件:假设A的全部产生式为A1|2|n ,则必须满足如下条件才能保证可以唯一的选择合适的产生式predict(Ai)predict(Aj)=,当ij.五、实验步骤 1求SNL文法中每个产生式Predict集合 Predict(A) = First() , 当First()= (First()- ) Follow(A),当First() 根据Predict集合的定义求SNL的文法中每个产生式的Predict集合,判断是否满足递归下降法分析条件,若不满足用消除左递归和消除公共前缀等文法等价变化算法对文法进行变换,使其满足递归下降法的要求。2. 构造递归下降语法分析程序采用了递归子程序

    17、方法进行语法分析,对文法中的每个非终极符号按其产生式结构产生相应的语法分析子程序,完成相应的识别任务。其中终结符产生匹配命令,非终结符则产生调用命令。每次进入子程序之前都预先读入一个单词。因为使用了递归下降方法,所以程序结构和层次清晰明了,易于手工实现,且时空效率较高。实际的语法分析工作,从调用总程序的分析子程序开始,根据产生式进行递归调用各个分析子程序。附录A 部分课程设计题目参考源程序A.1 基于语法制导翻译的表达式转换编译器参考源程序/*全局头文件myglobal.h,用于存放需加载的头文件、宏定义、全局变量*/#include #include #include /* 加载字符测试函数

    18、*/#define BUFSIZE 128 /* 定义缓冲区大小*/#define NONE -1#define EOSTR 0#define NUM 256#define DIV 257#define MOD 258#define ID 259#define DONE 260int tokenval; /* 定义单词属性值*/int lineno;struct table /* 定义符号表结构*/ char *lexptr; int token;struct table symtable;/* 定义符号表*/*词法分析程序lex.c*/#include “global.h”char lexb

    19、ufBUFSIZE;int lineno=1;int tokenval=NONE;int lex() /*词法分析函数*/ int t;while(1)t=getchar();if (t=| t=t) ; /*滤掉空格*/else if (t=n) lineno+;else if (isdigit(t) ungetc(t,stdin); scanf(“%d”,&tokenval); return NUM;else if (isalpha(t) int p,b=0; while(isalnum(t) lexbufb=t;t=getchar();b=b+1;if (bBUFSIZE) error(

    20、“compiler error!”); lexbufb=EOSTR;if (t!=EOF) ungetc(t,stdin);p=lookup(lexbuf);if (p=0) p=insert(lexbuf,ID); tokenval=p;return sysmtablep.token; else if (t=EOF)return DONE; else tokenval=NONE;return t; /*语法分析程序paserx.c*/#include “global.h”int lookahead;void parse() lookahead=lex(); while (lookahead!

    21、=DONE) express();match(;);void express() int t; void term(); while (1) switch(lookahead) case +: case -:t= lookahead;match(lookahead); term(); emit(t,NONE); continue;default: return; void term()int t; void factor(); while (1) switch(lookahead) case *: case /: case DIV: case MOD:t= lookahead;match(lo

    22、okahead); factor(); emit(t,NONE); continue;default: return; void factor() switch(lookahead) case (:match();express();match();break; case NUM:emit(NUM,tokenval);match(NUM);break;case ID:emit(ID,tokenval);match(ID);break;default: error(“syntax error”); void match(int t) if (lookahead=t) lookahead=lex(

    23、);else error(“syntax error”);/*输出程序emitter.c*/#include “global.h”voidemit(int t,int tval) switch(t) case +: case -: case *: case /:printf(“%cn”,t);break;case DIV:printf(“DIVn”);break;case MOD:printf(“MODn”);break; case NUM:printf(“%dn”,tval);break; case ID:printf(“%sn”,symtabletval.lexptr);break;def

    24、ault:printf(“token %d, tokenval %dn”,t,tval);/*符号表处理程序symbol.c*/#include “global.h”#define STRMAX 999#define SYMMAX 100char lexemesSTRMAX;int lasrchar=-1;struct entry symtableSYMMAX;int lastentry=0;int lookup(char *s) int p; for (p=lastentry;p0;p-) if (strcmp(symtablep.lexptr,s)=0) return p; return

    25、0;int insert(char *s,int tok) int len; len=strlen(s); if (lastentry+1=SYMMAX) error(“symbol table full”); if (lastchar+len+1=STRMAX) error(“lexemes array full”);lastentry=lastentry+1;symtablelastentry.token=tok;symtablelastentry.lexptr=&lexemeslastchar+1;lastchar=lastchar+len+1;strcpy(symtablelasten

    26、try.lexptr,s);return lastentry;/*在符号表中填入关键字程序init.c*/#include “global.h”struct entry keywords=“div”,DIV,“mod”,MOD,0,0void init() struct entry *p; for (p=keywords;p-token;p+) insert(p-lexptr,p-token);/*错误处理程序error.c*/#include “global.h”void error( char *m) fprintd(stderr,“line %d: %sn”,lineno,m); exit(1); /*


    注意事项

    本文(编译原理实验题目解析.docx)为本站会员主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2022 冰点文档网站版权所有

    经营许可证编号:鄂ICP备2022015515号-1

    收起
    展开