- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
该设计论文已经通过各大高校老师审核认可并通过答辩,准确完整无误。欢迎大家下载学习交流。如有疑问可随时联系店主,竭诚为您解答!!
基于GUI的交互式编译系统之中间代码生成器的设计与实现
摘要
本设计实现了一个编译器前端,它将一个用C语言的子语言编写的源程序翻译成中间代码。词法分析器、语法分析器、中间代码生成器均是采用C++语言手动书写完成,未采用自动生成器,GUI采用Win32 API实现以保证轻快的运行速度及良好的系统性能,编辑控件采用Scintilla。词法分析器采用确定有限自动机实现,语法分析器是一个递归下降分析器,中间代码生成器输出的中间代码以四元式形式表示。
本设计实现的编译器前端,运行在Windows平台下,Windows系统版本为Windows XP、Windows 7或更高版本。本设计提供了一个可工作的界面友好的编译器前端,可以用来理解编译原理及解释怎样用一种语言如C++实现编译器前端,以供学习和教学所用。
关键词:编译器前端;GUI;C++
Design Implementation of Intermediate Code Generator of Interactive Compilation System Based GUI
Abstract
This final project implements a compiler front-end, it translates source programs written in a subset of the C language into intermediate code. The lexer、parser and intermediate code generator are all hand-written in C++, no auto lexer or parser are used, GUI is implemented in Win32 API for fast running speed and high performance, and edit control uses Scintilla. The lexer is implemented in Deterministic finite automata,the parser is a recursive-descent parser, the intermediate codes are represented in quadruple。
The compiler front-endruns on the Windows platform, Windows system version is Windows XP, Windows 7 or later.This project provide a working and user interface friendly compiler front-end, which can be used to demonstrate compiler principle and how compilers can be implementedin a language such as C++, for learning and teaching.
Keywords: compiler front-end; GUI; C++
目录
1 绪论 1
2 基本原理 3
2.1 词法分析 4
2.1.1 词法分析结果 4
2.1.2 确定有限自动机 5
2.2 语法分析 5
2.2.1 递归下降分析法 6
2.2.2 运算符的优先级 8
2.3 中间代码生成 9
2.3.1 四元式 9
2.3.2 四元式的常见结构 10
2.4 符号表 14
2.4.1 作用域 15
2.4.2 局部变量名的存储布局 16
3 设计与实现 17
3.1 C子语言 17
3.1.1数据类型 17
3.1.2 字面值 17
3.1.3 表达式 17
3.1.4 语句 18
3.1.5 函数 18
3.2 符号表 19
3.3 词法分析器 24
3.4 语法分析器 26
3.5 中间代码生成器 28
3.6 GUI 30
4 测试 36
总结 41
参考文献 42
致谢 43
附录源程序 44
附件1:开题报告(文献综述)
附件2:译文及原文影印件
1 绪论
很少有人去自己编写或修改编译器,那么为什么要去实现编译器前端呢?
很重要的一点就是,理解计算机程序怎样被编译以及执行,可以帮助任何程序员理解他们写的代码是怎样驱动计算机的,从而帮助他们写出更快、更高效的程序。
编译原理经过多年发展已日趋成熟,然而现代很多跟编译原理相关的教材,内容陈旧落后,比如以Fortran或Pascal等过时语言为例进行分析讲解,或者全书充满晦涩难懂的定理公式,不能以直观的方式进行阐述,致使学生望而生畏。本设计
您可能关注的文档
- 基于PLC的水泥自动配料控制系统设计.doc
- 基于PLC音乐喷泉系统控制设计.doc
- 基于ProE的蜗轮蜗杆减速器的建模与仿真.doc
- 基于proteus的信号发生器的设计.doc
- 基于socket通信的销售管理系统的设计与实现.doc
- 基于STM32的SD卡设计.doc
- 基于STM32的自行车转向刹车灯设计.doc
- 基于TOP_Switch_LED开关电源设计.doc
- 基于UC3845的单级反激式开关电源的设计.doc
- 基于UG平台的夹具设计.doc
- 毕业设计(论文)-基于J2EE架构的企业煤炭销售管理系统的设计与实现.doc
- 毕业设计(论文)-基于Java的仿QQ聊天系统.doc
- 毕业设计(论文)-基于JAVA平台的工资管理系统.doc
- 毕业设计(论文)-基于MATLAB的DICOM医学图像浏览器设计.doc
- 毕业设计(论文)-基于Matlab的汽车牌照识别方法研究.doc
- 毕业设计(论文)-基于MATLAB的语音信号PCM编译码实现.doc
- 毕业设计(论文)-基于PLC_S7-200交通信号灯的控制系统设计.doc
- 毕业设计(论文)-基于PLC的U型板折板机控制系统.doc
- 毕业设计(论文)-基于PLC的花园喷泉设计.doc
- 毕业设计(论文)-基于PLC的机械手设计.doc
最近下载
- 高危学生家长知情同意书.docx
- 人教版九年级上册物理全册新优质教学课件(配2025年秋改版教材).pptx
- 2025年新人教版7年级道德与法治上册全册教学课件.pptx
- 高频电子线路课程设计石英晶体振荡器电路设计.doc VIP
- 健康教育处方.pdf VIP
- 2022年自考00315当代中国政治制度核心考点资料.pdf VIP
- 烟草 打击物流寄递渠道涉烟违法犯罪活动专项行动实施方案.docx VIP
- 人教版八年级物理全册课件(共464张课件).ppt VIP
- 纪念中国人民抗日战争抗战胜利80周年暨世界反法西斯战争胜利80周年.pptx
- 设置安全生产管理机构和配备专职安全生产管理人员的文件74923.pdf VIP
文档评论(0)