基于llvm的编译器的设计与实现

基于llvm的编译器的设计与实现

ID:11707097

大小:2.09 MB

页数:106页

时间:2018-07-13

基于llvm的编译器的设计与实现_第1页
基于llvm的编译器的设计与实现_第2页
基于llvm的编译器的设计与实现_第3页
基于llvm的编译器的设计与实现_第4页
基于llvm的编译器的设计与实现_第5页
资源描述:

《基于llvm的编译器的设计与实现》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、学士学位论文题目:基于LLVM的编译器的设计与实现设计人:梁关林指导教师:刘爱琴所属系部:计算机科学与技术学院专业班级:计算机082001班2012年6月4日太原科技大学毕业设计(论文)任务书学院:计算机科学与技术学院学生姓名梁关林学号200820010114专业班级计算机082001同组人无任务下发时间2012年3月任务完成时间2012年6月设计(论文)题目基于LLVM的编译器的设计与实现设计目的要求高质量应用软件的开发,需要高效的编程语言和编译器的支持。为了加深学生对编程语言和编译器的理解,要求学生设计一

2、个类似C的小源语言,然后利用LLVM实现该语言的编译器。设计主要内容在深刻理解编译原理,掌握文法设计和编译器构造方法,并且熟悉LLVM的基础上,完成编程语言和编译器的设计。主要内容包括:(1)设计源语言,要求包括变量声明,基本赋值语句,数组访问,条件分支语句,循环语句,函数定义,和函数调用等。(2)学习LLVM,完成词法分析,语法分析,和语法制导翻译(翻译成LLVMIR)工作,最后利用LLVM实现代码优化和代码生成功能。设计提交资料毕业论文外文资料翻译编译器软件学生签名指导教师签名系主任签名主管院长签名太原科

3、技大学学士学位论文中文摘要开发高性能的应用软件,除了一个良好的软件架构外,还需要高效的编程语言和高质量的编译器的支持。现有语言的改动和新语言的创造,都会带来编译器的开发需求。本文设计了一门新的编程语言leechee,定义了此种语言的文法结构、词法规则,并在linux环境下实现了leechee编程语言的编译器。具体实现方式为首先利用Flex完成词法分析,而后使用Bison完成文法设计、语法分析和语法制导翻译,把源代码翻译成LLVMIR,最后利用LLVM实现代码优化和代码生成功能。关键字:编程语言;编译器;语法制

4、导翻译;LLVMIR;代码优化IV太原科技大学学士学位论文TheDesignandImplementationofLLVMbasedCompilerAuthor:LiangGuanlinTutor:LiuAiqinABSTRACTInadditiontoagoodsoftware-architecture,thedevelopmentofhigh-performanceapplicationsalsoneedsthesupportofanefficientprogramminglanguageandahigh

5、-qualitycompiler.Changestoexistinglanguagesandcreationofnewlanguages,willbringthedevelopmentneedsofthecompilers.Thispaperdesignsanewprogramminglanguageleechee,definesitsgrammaticalstructures,lexicalrules,andimplementsitscompilerunderLinuxenvironment.Thespec

6、ificapproachis,first,finishesthescannerwithFlex,andthencompletesthegrammardesign,parser,syntaxdirectedtranslationwithBison,implementsthetranslationtoLLVMIR,andfinallyusetheLLVMtodothecodeoptimizationandcodegeneration.Keywords:programminglanguage;compiler;sy

7、ntaxdirectedtranslation;LLVMIR;codeoptimizationIV太原科技大学学士学位论文目录第一章绪论11.1什么是编译器11.2总会有编译器的开发需求11.3为什么做这个项目2第二章设计什么样的编译器和语言42.1做一个什么样的编译器42.1.1利用LLVM实现一门新语言42.1.2利用flex和bison完成词法分析和语法分析52.2设计一个什么样的语言62.2.1计算机可以做什么62.2.2本设计的语言——leechee7第三章相关技术的介绍83.1Flex83.1.1

8、Flex输入文件的格式83.2Bison93.2.1Bison的语法文件93.2.2文法规则的语法103.2.3文法设计需要注意的问题113.3LLVM123.3.1LLVMIR123.3.2LLVM对三段式设计的实现133.3.3利用LLVM完成代码优化15第四章语言和编译器的设计174.1语言设计174.1.1leechee的数据组成174.1.2leechee的文法规则18IV太原科技大学学士

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。