编译原理完整学习笔记(五):属性文法和语法制导翻译

2023-11-01 19:31

本文主要是介绍编译原理完整学习笔记(五):属性文法和语法制导翻译,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

如果你对这篇文章可感兴趣,可以点击「【访客必读 - 指引页】一文囊括主页内所有高质量博客」,查看完整博客分类与对应链接。

文章目录

    • 前言
    • 属性文法和语法制导翻译
      • 一、概述
        • 1.1 综合属性
        • 1.2 继承属性
        • 1.3 语义规则
      • 二、带注释的语法树
        • 2.1 S-属性文法
        • 2.2 L-属性文法
      • 三、属性计算
        • 3.1 概述
        • 3.2 语法制导翻译法
        • 3.3 依赖图
          • 3.3.1 构建算法
          • 3.3.2 依赖图举例
          • 3.3.3 属性的计算次序
        • 3.4 树遍历
          • 3.4.1 树遍历算法
          • 3.4.2 树遍历举例
        • 3.5 一遍扫描
          • 3.5.1 抽象语法树
          • 3.5.2 建立抽象语法树
          • 3.5.3 一遍扫描举例
    • 资料来源


属性文法和语法制导翻译

一、概述

属性文法,也称为属性翻译文法,以 “上下文无关文法” 为基础,扩充了以下两部分内容:

  • 每个文法符号(终结符或非终结符)有 “值”(属性)
  • 每个产生式有一组属性的语义规则,对属性进行计算和传递

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8Rc3D5XP-1597633504396)(media/15892523842959.jpg)]

属性中有两类属性,一种是综合属性,另一种是继承属性。

1.1 综合属性
  • 自下而上传递信息
  • 语法规则:产生式右部确定左部

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5DUdISAo-1597633504400)(media/15892526840515.jpg)]

  • 语法树:子节点确定父节点

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-NRTKo3d6-1597633504403)(media/15892527144167.jpg)]

1.2 继承属性
  • 自上而下传递信息
  • 语法规则:产生式左部确定右部

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AE7vVOgJ-1597633504404)(media/15892528247818.jpg)]

  • 语法树:(父节点 + 兄弟节点)确定(子节点)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-O0dtDFui-1597633504405)(media/15892528777996.jpg)]

1.3 语义规则

产生式 A → α A\rightarrow \alpha Aα 对应的语义规则如下:
b : = f ( c 1 , c 2 , . . . , c k ) b:=f(c_1,c_2,...,c_k) b:=f(c1,c2,...,ck)
其中共有两种情况:

  • b 是 A 的综合属性, c i c_i ci 是产生式右边文法符号的属性
  • b 是产生式右边文法符号的继承属性, c i c_i ci 是 A 或产生式右边文法符号的属性

由此可以如下结论:

  • 终结符只有综合属性,且由词法分析器提供
  • 非终结符可以有综合属性、继承属性
  • 文法开始符号的所有继承属性作为属性计算前的初始值

语义规则功能:

  • 属性计算、静态语义检查
  • 符号表操作、代码生成

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QMpMOGZt-1597633504405)(media/15892538453566.jpg)]

二、带注释的语法树

2.1 S-属性文法
  • 语法树中,一个结点的综合属性的值由其子结点和它本身的属性值确定
  • 使用自底向上的办法在每一个结点处使用语义规则计算综合属性的值
  • 仅使用综合属性的属性文法为 S-属性文法

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Y9juqgUB-1597633504406)(media/15892612853527.jpg)]

  • 分析过程
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-fiAx0561-1597633504406)(media/15922112717264.jpg)]
2.2 L-属性文法

语法树中,结点的继承属性由其父结点、其兄弟结点和其本身的某些属性确定。

  • 继承属性,常用于表示上下文依赖关系

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BZqkIJiZ-1597633504407)(media/15892613875832.jpg)]

  • 文法定义
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SxF5IKBZ-1597633504407)(media/15922111699746.jpg)]

三、属性计算

3.1 概述

语义规则的计算功能如下:

  • 产生代码
  • 在符号表中存放信息
  • 给出错误信息
  • 执行任何其它动作

「总结」对输入串的翻译就是根据语义规则进行计算。

3.2 语法制导翻译法

语法制导翻译法:由源程序的语法结构所驱动的处理办法
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VtEANdJK-1597633504408)(media/15892618009527.jpg)]

基于属性文法的处理方法有:

  • 依赖图
  • 树遍历
  • 一遍扫描
3.3 依赖图

「功能」描述一棵语法树中的结点的继承属性和综合属性之间的相互依赖关系

3.3.1 构建算法

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WnBbGeUT-1597633504409)(media/15892650094231.jpg)]

3.3.2 依赖图举例

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TYfjWGSG-1597633504410)(media/15892650332609.jpg)]

  • 如果一属性文法不存在属性之间的循环依赖关系,则该文法为良定义的
  • 一个依赖图的任何拓扑排序都给出一个语法树中结点的语义规则计算的有效顺序
3.3.3 属性的计算次序

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vbFq3X9o-1597633504410)(media/15892651743803.jpg)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YWiDTh0D-1597633504411)(media/15892652559998.jpg)]

3.4 树遍历

「具体方法」通过树遍历的方法计算属性的值

  • 输入时,树中已有开始符号的继承属性和终结符的综合属性
  • 深度优化,从左到右的遍历

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-N7aQHHoJ-1597633504411)(media/15892661489408.jpg)]

3.4.1 树遍历算法

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kEnNcQOF-1597633504412)(media/15892661947124.jpg)]

3.4.2 树遍历举例

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nddjpMjX-1597633504413)(media/15892662280687.jpg)]

3.5 一遍扫描
  • 在语法分析的同时计算属性值
  • 适用于 S-属性文法 / L-属性文法
3.5.1 抽象语法树

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-brxGPTNM-1597633504413)(media/15892669752285.jpg)]

3.5.2 建立抽象语法树

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Qb93KAzu-1597633504414)(media/15892670047060.jpg)]

3.5.3 一遍扫描举例

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-60ZsNJX6-1597633504414)(media/15892670363976.jpg)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uFMg1ITC-1597633504415)(media/15892670653695.jpg)]


资料来源

  • 编译原理 - 国防科技大学 - MOOC

这篇关于编译原理完整学习笔记(五):属性文法和语法制导翻译的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/325240

相关文章

ESP32 esp-idf esp-adf环境安装及.a库创建与编译

简介 ESP32 功能丰富的 Wi-Fi & 蓝牙 MCU, 适用于多样的物联网应用。使用freertos操作系统。 ESP-IDF 官方物联网开发框架。 ESP-ADF 官方音频开发框架。 文档参照 https://espressif-docs.readthedocs-hosted.com/projects/esp-adf/zh-cn/latest/get-started/index

51单片机学习记录———定时器

文章目录 前言一、定时器介绍二、STC89C52定时器资源三、定时器框图四、定时器模式五、定时器相关寄存器六、定时器练习 前言 一个学习嵌入式的小白~ 有问题评论区或私信指出~ 提示:以下是本篇文章正文内容,下面案例可供参考 一、定时器介绍 定时器介绍:51单片机的定时器属于单片机的内部资源,其电路的连接和运转均在单片机内部完成。 定时器作用: 1.用于计数系统,可

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

[word] word设置上标快捷键 #学习方法#其他#媒体

word设置上标快捷键 办公中,少不了使用word,这个是大家必备的软件,今天给大家分享word设置上标快捷键,希望在办公中能帮到您! 1、添加上标 在录入一些公式,或者是化学产品时,需要添加上标内容,按下快捷键Ctrl+shift++就能将需要的内容设置为上标符号。 word设置上标快捷键的方法就是以上内容了,需要的小伙伴都可以试一试呢!

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

AssetBundle学习笔记

AssetBundle是unity自定义的资源格式,通过调用引擎的资源打包接口对资源进行打包成.assetbundle格式的资源包。本文介绍了AssetBundle的生成,使用,加载,卸载以及Unity资源更新的一个基本步骤。 目录 1.定义: 2.AssetBundle的生成: 1)设置AssetBundle包的属性——通过编辑器界面 补充:分组策略 2)调用引擎接口API

C++工程编译链接错误汇总VisualStudio

目录 一些小的知识点 make工具 可以使用windows下的事件查看器崩溃的地方 dumpbin工具查看dll是32位还是64位的 _MSC_VER .cc 和.cpp 【VC++目录中的包含目录】 vs 【C/C++常规中的附加包含目录】——头文件所在目录如何怎么添加,添加了以后搜索头文件就会到这些个路径下搜索了 include<> 和 include"" WinMain 和

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

大学湖北中医药大学法医学试题及答案,分享几个实用搜题和学习工具 #微信#学习方法#职场发展

今天分享拥有拍照搜题、文字搜题、语音搜题、多重搜题等搜题模式,可以快速查找问题解析,加深对题目答案的理解。 1.快练题 这是一个网站 找题的网站海量题库,在线搜题,快速刷题~为您提供百万优质题库,直接搜索题库名称,支持多种刷题模式:顺序练习、语音听题、本地搜题、顺序阅读、模拟考试、组卷考试、赶快下载吧! 2.彩虹搜题 这是个老公众号了 支持手写输入,截图搜题,详细步骤,解题必备

UE3脚本UnrealScript UC语法点滴

持续更新 目录 类定义修饰符  1.dependson(CLASSNAME) 2.config(ININAME) 3.native 4.notplaceable 5.inherits(CLASSNAME1[,CLASSNAME2,...]) 类对象实例创建 类默认属性设置 变量 1.声明 var local 2.修饰符 config  3.array 类型变量 以及