编译器-编译原理课程设计(共62页)

上传人:工**** 文档编号:552175461 上传时间:2023-11-26 格式:DOC 页数:63 大小:1MB
返回 下载 相关 举报
编译器-编译原理课程设计(共62页)_第1页
第1页 / 共63页
编译器-编译原理课程设计(共62页)_第2页
第2页 / 共63页
编译器-编译原理课程设计(共62页)_第3页
第3页 / 共63页
编译器-编译原理课程设计(共62页)_第4页
第4页 / 共63页
编译器-编译原理课程设计(共62页)_第5页
第5页 / 共63页
点击查看更多>>
资源描述

《编译器-编译原理课程设计(共62页)》由会员分享,可在线阅读,更多相关《编译器-编译原理课程设计(共62页)(63页珍藏版)》请在金锄头文库上搜索。

1、广西大学编译原理课程设计 专 业: 计算机科学与技术 姓 名: 课 程: 编译原理 指导教师: 目录一程序简介与分析-1二程序适用范围-1三词法分析-1四语法分析-3五语义分析和中间代码生成-9六代码生成-11七流程图-12八实现-13九程序运行结果-13十总结-18十一.附录(源程序)-19 简单的编译程序设计一 程序简介与分析 本程序由四个部分组成:词法分析子程序,语法分析子程序,语义分析子程序,目标代码生成程序。本程序输入一个叫haominjie.txt的c语言源程序,然后对它进行词法,语法,语义分析,并输出汇编代码。 词法分析输入的是c语言源程序,输出的3是具有独立语法意义的单词符号。

2、 语法分析以词法分析产生的编码流为输入,按照SLR(1)分析方法进行语法分析,产生语法树,输出移进和归约的动作,如果源程序不符合文法,则有“语法分析出错”的提示。 语义分析阶段,在语法分析的同时,在归约的时候,给出相应的语义动作,最后输出中间代码四元式和新的符号表,如果有未声明的变量出现,则会提示出出错,并显示出此变量的名称。 代码生成阶段,将语义分析得到的中间代码四元式转化为汇编语言的目标代码并输出。二 程序适用范围 本程序的使用范围为:整型常量,四则运算(为了简化问题,本程序只考虑加法运算和乘法运算)和布尔表达式以及相应的赋值语句,条件转移语句和循环语句。三 词法分析 根据词法分析的需要,

3、我将源程序中的单词符号分为:保留字,字母(标识符), 界符三类,统一用一张表表示如下:界符,保留字表单词=+*:;()andifthenwhiledoint标志符编码1234567891031323335363725 程序从源程序文件haominjie.txt中一次读入一个字符,并判断它是不是字母,界符, 保留字,空格,换行,结束符号或者非法字符。 流程图如下: 词法分析流程图四 语法分析源程序中涉及的文法GP定义如下表:说明语句表达式布尔表达式句法0、PP1、Pid () L;R2、LL;D3、LD4、Did:int5、EE+T6、ET7、TT*F8、TF9、F(E)10、Fid11、BB

4、and B12、Bidid13、Mid=E14、Sif B then M15、Swhile B do M16、SM17、NN;S18、NS19、RN.上述文法的每个非终结符的FIRST 集和FOLLOW集如下表: FIRST 集 FOLLOW 集P id # L id ; D id ; E (,id ,;,+,),#T (,id ,;,+,),*,#F (,id ,;,+,),*,#B id then,do,andM id ,; S id,while,if ,; N id,while,if ,; R # .文法GP的项目集部分如下:0. P.P 1. PP.2. P.id()L;R 3. Pi

5、d.()L;R 4. Pid(.)L;R 5. Pid().L;R 6. Pid()L.;R 7. Pid()L;.R 8. Pid()L;R. 9. L.L;D10.LL.;D 11. LL;.D 12. LL;D. 13.D.id:int 14. Did .:int 15. Did: .int 16. Did:int. 17.E.E+T 18. EE.+T 19. EE+.T 20. EE+T. 21. E.T 22. ET. 23. T.T*F 24. TT.*F 25. TT*.F 26. TT*F. 27. T.F 28. TF. 29. F (E) 30. F (.E) 31. F

6、 (E.) 32. F (E). 33. F.id 34. Fid. .再由项目集构造文法的DFA活前缀。为了方便,省去了项目族集的每个状态的项目,直接在状态转换的箭头上标明终结符或非终结符。对于有规约动作和接受的状态,将其特别标明。文法GP的DFA图如下: 有归约动作812765 : int 说明语句接受状态 D id D id3021491011R ; L ) ( id P26252423 if B then M271430292028191718222113 id and id 句法S id = if idM N ; S id M while while B do M id and353431 id B 布尔表达式 and3233 id1536 T id38 id ( F E3716 * (403941 F ( id F id + E ( 表达式4342 + ) T4445 *GP:SLR(1)分析

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号