- 1、本文档共110页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
编译原理语义分析详解
machunyan 西北工业大学软件与微电子学院 * 5.1 属性和属性文法 5.2 符号表 5.3 数据类型和类型检查 文法符号语义信息的计算技术 语义分析的两个主要方面 第5章 语义分析 machunyan 西北工业大学软件与微电子学院 * 5.3 数据类型和类型检查 编译器的主要任务之一是数据类型信息的计算和维护(类型推论(type inference))以及使用这些信息确保程序的每一部分在语言的类型规则作用下有意义(类型检查(type checking))。 由编译器完成的检查称为静态检查,在大多数传统语言中,如Pascal、C和Ada,类型信息主要是静态的,主要在程序执行之前进行正确性检查。 在目标程序运行时完成的检查则称为动态检查。原则上,如果目标代码将每个元素的类型和其值保存在一起,则任何检查都可以动态完成。 machunyan 西北工业大学软件与微电子学院 * 5.3 数据类型和类型检查(续) 类型检查: 类型检查器将验证结构的类型是否与上下文所期望的类型匹配; 类型检查器必须能够验证指针地址访问只作用于指针,下标运算只作用于数组,用户自定义的函数只能用于有正确参数个数及参数类型等情况。 machunyan 西北工业大学软件与微电子学院 * 类型等价 例如,当对一个表达式或函数调用的形式参数和实在参数进行类型检查时,通常必须进行类型的比较以确定它们是否与给定的上下文相匹配。 编译器有一个语义分析程序: Boolean typeEqual(t1,t2:TypeExp); 该语义分析程序接受两个类型表达式,如果根据语言的类型等价规则(C语言和Java举例)它们表示相同的类型就返回true,否则返回false。 machunyan 西北工业大学软件与微电子学院 * 下面对一个简单语言的语义分析动作方面的类型检查器进行描述,该语言的语法描述如下: var-decl→ id:type-exp type-exp→int type-exp→bool type-exp1→array[num] of type-exp2 exp1→exp2+exp3 exp1→exp2 or exp3 exp1→exp2[exp3] exp→num exp→true exp→false exp→id stmt→if exp then stmt stmt→ id:=exp machunyan 西北工业大学软件与微电子学院 * 符合上述语法的合法的变量声明举例: a: array[4] of int y:bool y:= a[3] 为了对上述简单语言的类型检查器进行描述,从三个方面来撰写其类型检查方面的语义规则。1)类型声明;2)表达式的类型检查;3)语句的类型检查; machunyan 西北工业大学软件与微电子学院 * 1.类型声明 声明引起标识符的类型插入符号表。 产生式 语义规则 var-decl→ insert(id.name,type-exp.type) id:type-exp type-exp→int type-exp.type:=integer type-exp→bool type-exp.type:=boolean machunyan 西北工业大学软件与微电子学院 * type-exp1→array[num] of type-exp2 type-exp1.type:= makeTypeNode(array.num.val, type-exp2.type) array.num.val type-exp2.type machunyan 西北工业大学软件与微电子学院 * 2.表达式的类型检查 产生式 语义规则 if not(typeEqual(exp2.type, integer) and typeEqual(exp3.type,integer)); then type-error(exp1); exp1→exp2+exp3 exp1.type:=integer; machunyan 西北工业大学软件与微电子学院 * if not(type Equal(exp2.type, boolean) and typeEqual(exp3.type, boolean)); then type-error(exp1); exp1.type:= boolean; exp1→exp2 or exp3 machunyan 西北工业大学软件与微电子学院 * 产生式 语义规则 exp1→exp2[exp3] if isArrayType(exp2.type) and typeEqu
您可能关注的文档
- 绿城集团地下室防水及防结露体系介绍及技术交底(图文并茂)详解.ppt
- 教学课件:情境7-1个人所得税税款计算分解.ppt
- 绿色施工管理制度详解.docx
- 绿色施工示范工程管理办法(2014版试行)详解.doc
- 家畜环卫学:畜禽舍建筑结构设计与类型选择分解.ppt
- 绿色开采课程总结详解.ppt
- 绿色涂料水性聚氨酯漆的研究详解.doc
- 绿色环保祝福贺卡详解.ppt
- 绿色施工5.17详解.ppt
- 绿色溶剂介绍详解.ppt
- 2024-2025学年人教版小学数学四年级下册教学计划及进度表.docx
- 2024-2025学年北师大版小学数学二年级下册教学计划及进度表.docx
- 2024-2025学年人教版小学数学五年级下册教学计划及进度表.docx
- 2024-2025学年人教大同版(2024)小学英语三年级下册教学计划.docx
- 2024-2025学年人教精通版(三起)(2024)小学英语三年级下册教学计划.docx
- 2024-2025学年统编版初中道德与法治八年级下册教学计划及进度表.docx
- 2024-2025学年统编版(2024)初中道德与法治七年级下册教学计划及进度表.docx
- 2023-2024学年上海黄埔区中考二模综合测试(物理部分)试卷及答案.pdf
- 2024-2025学年外研版(三起)(2024)小学英语三年级下册教学计划及进度表.docx
- 2025届北京市北京第四中学高三冲刺模拟数学试卷含解析.doc
最近下载
- 统编版(新教材)一年级下册语文第二单元《热爱中国共产党》第1课时教学课件.pptx VIP
- SAE AMS8660-2018 硅酮化合物代号S-736.pdf
- 2024年统编版(高中)政治新教材必修3政治与法治第一次月考试卷 2套汇编(含答案解析).pdf
- “技能兴威”第一届威海市职业技能大赛“无人机操控”赛项实施方案.docx
- 2024年阳泉职业技术学院单招职业技能测试题库及答案(必刷).docx VIP
- 武汉市2025届高中毕业生二月调研考试(二调)数学试卷(含答案详解).pdf
- 《基于哈佛分析框架的房地产公司财务研究国内外文献综述5100字》.pdf VIP
- 新12J01图集 工程作法.pdf
- 《热爱中国共产党》课件-2024-2025学年统编版语文一年级下册第二单元阅读1.pptx VIP
- 详解2025《增值税法》课件.ppt
文档评论(0)