- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理复习汇总
复习汇总第一章概述文法与自动机的等价0型文法—图灵机1型文法—线性有界非确定图灵机2型文法—非确定下推自动机3型文法—有限状态自动机编译技术的应用语法制导的结构化编辑器程序格式化工具软件测试工具程序理解工具高级语言的翻译工具等等从面向机器的语言到面向人类的语言(结合第二章第9小点理解)面向机器的语言:机器指令,汇编语言面向人类的语言:通用程序设计语言,数据查询语言,形式化描述语言(正规式,产生式)等等。各语言的分类(结合第二章第9小点理解)过程式语言,面向对象语言:通用程序设计语言。函数语言:面向特点领域的,递归特性。例如LISP语言说明性,非算法式语言:LEX/YACC,SQL。脚本式语言:Shell语言语言之间的转换(李静PPT41)高级语言之间的转换一般称为预处理或转换。高级语言翻译成汇编语言或机器语言称之为编译。把汇编语言翻译成机器语言称之为汇编。将一个汇编语言程序汇编为可在另一台机器上运行的机器指令称之为交叉汇编。把机器语言翻译成汇编语言称之为反汇编。把汇编语言翻译成高级语言称之为反编译。编译器和解释器编译器源程序的翻译和翻译后的程序的运行是两个不同的阶段。编译阶段:用户输入源程序,经过编译器的处理,生成目标程序。目标程序的运行阶段:根据要求输入数据,得出结果。解释器(凡是可以采用编译器的地方均可以采用解释器)解释器把翻译和运行结合到一起,编译一段源程序,紧接着就执行它。这种方式称为解释。解释器的优点(对比与编译器)具有较好的动态特性。具有较好的移植特性。解释器的缺点(对比于编译器)相比于编译器需花费大量的时间。占用更多的内存空间。编译器的工作阶段(结合第二章6小点红色部分理解)源程序-词法分析器-语法分析器-语义分析器-中间代码生成器-代码优化器-目标代码生成器-目标代码工作过程中的每个阶段均采用了符号表管理器,出错处理器。编译器各阶段的工作过程(结合第二章6小点红色部分理解)源程序通过词法分析器翻译成记号流,记号流通过语法分析产生语法树,然后根据语法树来进行适当的语义处理,语义分析产生符号表和中间代码。符号表的格式:标识符,类型,分配的地址。中间代码的格式:操作符,左操作数,右操作数,结果。中间代码的优化:传值的代码可以省略。目标代码生成:生成汇编指令,格式为:操作数源码目标。二元运算: OP source target target := source OP target一元运算:MOVE source target tatget = source。各阶段工作归纳词法分析:根据词法规则识别出源程序的各个记号(token),每个记号代表一类单词(lexeme),记号的分类如下:(第二章第4小点)关键字:如var、begin、end等,不做他用,称为保留字。标识符:如x、y、z、sort等,在源程序中被用作变量名,过程名,类型名和标号等所有对象的名称。(用记号代替)字面量:如60、Xidian、University等,一般用于表示常数或字符串常量。(保留原样)特殊符号:=、*、+、-、;等运算符,分隔符(保留原样)。例:var x,y,z:real ; x:= y+z*60; var id1,id2,id3:real;id1:=id2+id3*60;语法分析:得到语言结构并以树来表示。语义分析:考察结构正确的句子是否语义合法。中间代码生成。中间代码优化。目标代码生成。符号表管理:合理组织符号,便于各阶段查找,填写等。出错处理:错误的种类—词法错,语法错,静态语义错,动态语义错。编译器的分析/综合模式。(PPT53)前端(分析):语言结构的分析。(语法和语义分析)后端(综合):语言意义的分析与处理。(代码的生成、优化)中间代码:前段与后端的分解。第二章词法分析词法分析:词法分析是编译过程中将字符流转换成为符号流的一个工作阶段,是编译的第一步操作,其后续工作是语法分析(配合第一章第11小点理解)。词法分析输入源代码。词法分析输出记号流。词法分析需要识别此发错无,即非法的符号、单词。但不识别语法错误。词法分析器的作用源程序由单词组成,单词是最小的语义单位。词法分析器的功能:扫描源程序字符流。按照源程序的语法规则识别出各类单词符号。产生用于语法分析的记号序列。填写符号表。辅助功能跳过源程序的注释和空白。把错误信息和源程序联系起来(错误定位)。宏预处理。模式(规则)(patten):将产生和识别单词的规则称为模式(规则)。记号(token):按照某个模式识别出来的元素称为记号。(第一章和本章第11小点一同理解)记号 = 记号的类别 +记号的属性。(用于识别)记号的类别:记号的类别可以用整形编码来表示。记号的属性:根据记号的类别不同,记号的属性可以用不同的表示方法,如relation(81)的属性值为一个有限的可枚举的集合,
您可能关注的文档
最近下载
- GB+16423-2020金属非金属矿山安全规程.docx VIP
- 2024《拔高训练之50类题型精练》九年级物理全一册.pdf
- 罗道病课件文档.ppt VIP
- T∕CACM 1021.89-2018 中药材商品规格等级 鸡内金.docx VIP
- 人教版(2024)九年级全一册物理全册教案.docx
- T/BGEA001-2019 预拌流态固化土填筑工程技术标准.pdf VIP
- (2025秋新版)二年级语文上册全册教案.pdf
- 涉诈风险账户审查表.doc VIP
- CATIA自由曲面教程教程分析.doc
- 2025云南昆明巫家坝建设发展有限责任公司及下属公司第三季度招聘23人笔试历年参考题库附带答案详解.docx
文档评论(0)