ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:320.59KB ,
资源ID:5505769      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-5505769.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(编译实验指导书.docx)为本站会员(b****3)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

编译实验指导书.docx

1、编译实验指导书 编 译 原 理 实验指导书太原理工大学计算机与软件学院2010 年 3 月编译原理实验适用专业:计算机 实验类别:专业实验实验时数:8学时一、 实验课程的性质、目的和任务1 培养学生初步掌握编译原理实验的技能。2 验证所学理论、巩固所学知识并加深理解。3 对学生进行实验研究的基本训练。二、 实验课程的内容、要求及学时分配1 词法分析程序的设计 词法分析阶段对源程序进行自左而右的扫描,将其从外部形式(字符串)变换成便于后几个阶段处理的内部形式,即分解出一个个有独立语法意义的单位(单词或符号),同时识别出与其相关的属性。(1) 目的:通过设计、编制、调试一个具体的词法分析程序,加深

2、对词 法分析原理的理解,并掌握在对程序设计语言源程序进行扫描过程 中将其分解为各类单词的词法分析方法。(2) 要求:选择某种程序设计语言(如:C+、C、PASCAL等)的源程序作为词法分析对象;从所选语言中选取一个适当大小的子集,可以选取一类典型单词,也可以尽可能使各种类型的单词兼顾到,编写一个规模适当的词法分析程序。(调试例子应有词法正确的,也有错误的或超出设计要求的字符串。) 词法分析流程图 读无符号数的程序流程图实验二、 逆波兰式生成程序 内容:掌握语法分析的基本思想,并用高级语言编写逆波兰式生成程序(6学时) 要求:利用逆波兰式生成算法编写程序,将从键盘上输入的算术表达式(中缀表达式)

3、转化成逆波兰式。 逆波兰表达式的生成过程涉及到运算符的优先级,下表中列出几个常用运算符的优先关系。+-*/()+-*/() 常用运算符优先关系矩阵如上表所示的优先关系矩阵表示了+,-,*,/,(,)等七种运算符之间的相互优先关系。“、”三种符号分别代表“大于”、“小于”、“相等”三种优先关系。左边的“”与右边的“(”之间没有优先关系存在,所以表中为空白。逆波兰表达式生成算法的关键在于比较当前运算符与栈顶运算符的优先关系,若当前运算符的优先级高于栈顶运算符,则当前运算符入栈,若当前运算符的优先级低于栈顶运算符,则栈顶运算符退栈。下面给出了逆波兰表达式生成算法的流程图。(为了便于比较相邻运算符的优

4、先级,需要设立一个工作栈,用来存放暂时不能处理的运算符,所以又称运算符栈)。 实验三、 语法分析程序的设计 语法分析阶段根据程序语言的语法规则,对词法分析产生的单词 序列进行语法检查。凡不合语法者,尽可能多和确切地指出错误(包括出错位置、原因和性质),否则,变换成各类语法范畴。(1) 目的:通过设计、编制、调试一个典型的语法分析程序,实现对词 法分析程序所提供的单词序列进行语法检查和结构分析,进一步掌 握常用的语法分析方法。(2) 要求:选择具有代表性的语法分析方法,如:LL(K)分析法、递归子程序法、运算符优先数法、LR(K)分析法等方法之一进行设计;选择对各种常见程序语言都通用的语法结构,

5、如赋值语句(尤指表达式)作为分析对象,并与所选语法分析方法要比较贴切;先写出BNF定义,如:赋值语句:=变量=表达式 表达式:=项表达式+项表达式-项 项:=因子项*因子项/因子 因子:= 初等量因子初等量 初等量:= (表达式)i 然后编写语法分析程序;调试:调试例子应包括符合语法规则的算术表达式,以及分析程序能够判别的若干错例。1 LL(1)语法分析方法 LL(1)分析器的逻辑结构 构造LL(1)分析表的算法如下:1)对于A:=D(DVN)且select(A:=D)=b1,b2bn 则MA,bi=RE(D)/R 表示:用D的逆替换A,重读当前字符.2)对于A:=a(aVT) 则MA,a=

6、RE()/C 表示:用的逆替换A,继续读入下一字符.3)对于A:=且select(A:=)=b1,b2bn 则MA,bi=RE()/R=/R4)对所有没出现在规则右部的首部的终结符a, 令Ma,a=RE()/C=/C5)对于#,令M#,#=succ,表示分析成功,结束.6)其他情况属于出错,在分析表中用空白表示.2 递归下降语法分析法 是一种确定的自顶向下分析法。又称递归子程序分析法。 思想: 对文法中每个非终结符(代表语法成分)编写一个子程序(或递归过程),用来识别它所表示的语法范畴。 例:赋值语句SV:=E变量 Vi | i(E)表达式 EE+T | E-T | T项 TT*F | T/F

7、 | F因子 FFP | P初等量 P(E) | i 消除左递归: SV:=E Vi | i (E) ET ( + | - ) T TF ( * | / ) F FP P P(E) | i赋值语句处理流程图: 变量处理流程图表达式处理流程图项处理流程图因子处理流程图 初等量处理流程图3 运算符优先数法 表达式文法GE的优先关系矩阵 + * ( ) i # + * ( = i # =4 SLR(1)语法分析方法 LR(K)分析器的逻辑结构 表达式文法的SLR(1)分析表状态 ACTION GOTO i + * ( )# E T F S0 S5 S4 1 23 S1 S6acc S2 r2 S7

8、r2r2 S3 r4r4r4r4 S4 S5 S4 8 2 3 S5 r6 r6r6r6 S6 S5S4 9 3 S7 S5S4 10 S8 S6S11 S9 r1S7r1r1S10 r3r3r3r3S11 r5r5r5r5三、基本要求: 学生可以从以上三个实验中选做两个。学生应在实验课前仔细阅读实验相关内容,明确实验的目的和要求,然后了解词法分析和语法分析的基本方法,利用一种高级语言(如C语言、C+语言、PASCAL语言等),编写无符号数的词法分析程序、逆波兰式生成程序、语法分析程序(一种方法)。调试程序后,打印程序代码及实验结果,写出实验报告。四、考核 以学生的实验报告、实验内容和做实验的表现为考核依据。五、参考资料崔冬华 冯秀芳编译原理简明教程电子工业出版社

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2