编译原理【第四+七章】

考试题

1、简述语法制导翻译的基本思想

将语法分析和语义分析结合起来,通过语法规则驱动语义动作执行,用于将源程序翻译成目标代码或中间代码。

通过使用属性和语义动作,编译器可以在语法分析的同时生成目标代码或中间代码,实现高效的翻译过程。

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

语法制导翻译(Syntax-Directed Translation, SDT)是一种在编译器中将语法分析和语义分析结合起来的方法,用于将源程序翻译成目标代码或中间代码。SDT的基本思想是通过语法规则驱动语义动作,从而完成翻译过程。

基本思想

语法制导翻译的基本思想是将语义动作(Semantic Actions)与语法规则(Grammar Rules)关联起来。在进行语法分析的同时,按照语法规则的推导顺序执行相应的语义动作,实现翻译功能。

主要组件

语法制导翻译通常由以下几个组件组成:

  1. 上下文无关文法(Context-Free Grammar, CFG)

    • 描述源语言的语法结构,通常表示为四元组 ( G = (V, \Sigma, R, S) )。
      • ( V ):非终结符集合
      • ( \Sigma ):终结符集合
      • ( R ):产生式规则集合
      • ( S ):开始符号
  2. 语义动作(Semantic Actions)

    • 关联到文法产生式的动作,用于计算属性值、生成代码或执行其他与翻译相关的操作。
  3. 属性(Attributes)

    • 与语法分析树中的节点相关联,用于存储与该节点相关的语义信息。属性分为两类:
      • 综合属性(Synthesized Attributes):从子节点传递到父节点。
      • 继承属性(Inherited Attributes):从父节点或兄弟节点传递到子节点。

属性文法(Attribute Grammar)

属性文法是上下文无关文法的一种扩展,其中每个产生式都与一组语义动作相关联。每个语法符号都可以有零个或多个属性。属性文法根据属性的计算方向分为两种主要类型:

  1. S-属性文法(S-Attributed Grammar)

    • 只使用综合属性,适合自底向上的语法分析(如LR分析)。
  2. L-属性文法(L-Attributed Grammar)

    • 允许综合属性和某些限制的继承属性,适合自顶向下的语法分析(如LL分析)。

语法制导定义(Syntax-Directed Definition)

语法制导定义(SDD)是在上下文无关文法的基础上,通过添加语义动作来描述语法制导翻译过程。语义动作通常使用花括号 {} 表示,并嵌入到文法规则中。

例子

考虑一个简单的算术表达式文法和对应的语法制导定义:

文法规则
E -> E1 + T { E.val = E1.val + T.val; }
E -> T     { E.val = T.val; }
T -> T1 * F { T.val = T1.val * F.val; }
T -> F     { T.val = F.val; }
F -> ( E ) { F.val = E.val; }
F -> num   { F.val = num.val; }
属性和语义动作
  • E, T, F 的属性 val 表示表达式的值。
  • num 的属性 val 存储数值。

过程

  1. 语法分析
    • 根据输入字符串,构建语法分析树(或语法分析栈)。
  2. 语义动作执行
    • 在语法分析的同时,按照文法规则执行相应的语义动作,计算属性值。

示例

对于输入 3 + 4 * 5,构建的语法分析树及其属性值如下:

       E.val = 23
      /     \
  E1.val=3  T.val=20
   |         |
  T.val=3   T1.val=4
   |         |
 F.val=3    F.val=5
   |         |
  num.val=3  num.val=4

小结

语法制导翻译的基本思想是通过语法规则驱动语义动作执行,将语法分析和语义分析结合起来。通过使用属性和语义动作,编译器可以在语法分析的同时生成目标代码或中间代码,实现高效的翻译过程。语法制导翻译方法在编译器的前端处理中起着关键作用,特别是在语法分析和中间代码生成阶段。

2、文法符号的属性有哪两类,两类属性的计算过程是怎样的?

在这里插入图片描述在这里插入图片描述计算8+5*2n是综合属性
算数表达式 int a,b,c 继承属性
在这里插入图片描述
在这里插入图片描述

一.给出下面表达式的语法树和有向无环图DAG。

(1)P201图7.2
(2)c=a*(b-c)+ d* (b-c)
(3)c=(a+b)*(c+d)-(a+b+c)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/672359.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

网络原理——TCP/IP--数据链路层,DNS

T04BF 👋专栏: 算法|JAVA|MySQL|C语言 🫵 今天你敲代码了吗 目录 数量链路层目的地址和原地址类型校验和 DNS 数量链路层 主要的协议是以太网协议.一个横跨数据链路层和 物理层的协议,既包含了数据链路层的内容, 也包含了⼀些物理层的内容 我们来了解一…

STM32作业实现(五)温湿度传感器dht11

目录 STM32作业设计 STM32作业实现(一)串口通信 STM32作业实现(二)串口控制led STM32作业实现(三)串口控制有源蜂鸣器 STM32作业实现(四)光敏传感器 STM32作业实现(五)温湿度传感器dht11 STM32作业实现(六)闪存保存数据 STM32作业实现(七)OLED显示数据 STM32作业实现(八)触摸按…

官网上线,一款令人惊艳的文本转语音模型:ChatTTS

近日,一个名为 ChatTTS 文本转语音模型的项目在github上横空出世,一经推出便引发极大关注,短短四天时间,已经狂揽了14.2k的Start量。 ChatTTS是一款专为对话场景设计的支持中英文的文本转语音(TTS)模型&…

AGM DAP-LINK 离线烧录报错信息分析

DAP-LINK 支持离线烧录。 即:先把要烧录的bin 烧录到DAP-LINK 中;然后DAP-LINK 可以脱离PC,上电后通过按键对目标板进行烧录。 CMSIS-DAP模式 跳线JGND断开,状态LED D4快闪,D3常亮(串口状态)。…

服务失败后如何重试?

服务失败后如何重试? 在分布式系统和网络应用程序中,重试策略对于有效处理瞬时错误和网络不稳定性至关重要。 重试策略能让系统在发生故障时多次尝试操作,从而提高最终成功的可能性。 下图显示了 4 种常见的重试策略。 01 线性回退 线性回…

LabVIEW开发中对RS-232、RS-485、RS-422通讯的比较及注意事项

本文介绍了LabVIEW开发中常用的RS-232、RS-485和RS-422通讯方式的区别及各自特点,详细说明了它们的适用场景和开发过程中需要注意的问题,帮助开发人员在选择和实现通讯方式时做出最佳决策。 详细说明 RS-232、RS-485、RS-422通讯简介 RS-232、RS-485和…

虚幻引擎5 Gameplay框架(四)

Gameplay重要类及重要功能使用方法(三) 虚幻的委托机制 虚幻委托之间的区别序列化就是是否可以在蓝图中执行 多播与单播的创建 制作功能:使用多播与单播将血条与血量进行实时更新首先新建一个单播与一个多播委托 实例化这两个委托的标签…

西门子电梯控制保姆级教程

一、电梯运行控制 1.电梯控制系统结构 可以理解是通过ip进行访问的 2.基于PLCSIM Adv与电梯仿真软件的控制环境搭建 虽然都是用一台电脑来控制,但是还是用以太网来连接 在FC块里面也要用两个DB块来放输入和输出 二、电梯对象的分析 在eet里面,用手动控制…

关于高版本 Plant Simulation 每次保存是 提示提交comm对话框的处理方法

关于高版本 Plant Simulation 每次保存是 提示提交comm对话框的处理方法 如下图 将model saving history 修改为None即可 关于AutoCAD 2022 丢失模板库的问题 从新从以下地址打开即可: D:\Program Files\Autodesk\AutoCAD 2022\UserDataCache\zh-cn\Template

LabVIEW步进电机的串口控制方法与实现

本文介绍了在LabVIEW环境中通过串口控制步进电机的方法,涵盖了基本的串口通信原理、硬件连接步骤、LabVIEW编程实现以及注意事项。通过这些方法,用户可以实现对步进电机的精确控制,适用于各种自动化和运动控制应用场景。 步进电机与串口通信…

python--面向对象-文件读写-异常

一、继承 定义一个类时,需要使用另外一个类的方法或属性,就可以通过继承实现 object是Python的顶级类,创建类是会自动继承,就拥有object中的方法 定义格式 # 类的定义 # 旧式类定义 一般在定义单个类时使用 class 类名:name N…

Nginx01-HTTP简介与Nginx简介(安装、命令介绍、目录介绍、配置文件介绍)

目录 HTTP简介HTTP原理查看访问网站的详细流程curl -vwget --debug 查看网站访问量HTTP协议版本HTTP协议交互HTTP 请求请求报文起始行请求头 HTTP响应响应报文起始行响应头 Nginx常见的Web服务常见网站服务 安装NginxNginx目录结构Nginx启动管理Nginx常用命令 Nginx配置文件主配…

牛客周赛 Round 45VP

这场应该是十分仁慈的一场了 1.签到&#xff1a;https://ac.nowcoder.com/acm/contest/84244/A AC代码&#xff1a; #include<bits/stdc.h> using namespace std; int a,b,c,d,e; int main() {cin>>a>>b>>c>>d>>e;int sabcde;if(s>1…

关于nodejs单线程

Node是使用C++语言写的一款JavaScrip解析器。 高并发 一般来说,高并发的解决方案就是多线程模型,服务器为每隔客户端请求分配一个线程,使用同步I/o,比如Apache就是这种策略,由于I/O一般都是耗时操作,因为这种策略很难实现高性能,但非常简单,可以实现复杂的交互逻辑。…

深度学习复盘与论文复现B

文章目录 1、Knowledge Review1.1 NLLLoss vs CrossEntropyLoss1.2 MNIST dataset1.2.1 Repare Dataset1.2.2 Design Model1.2.3 Construct Loss and Optimizer1.2.4 Train and Test1.2.5 Training results Pytorch-Lightning MNIST :rocket::fire:1.3 Basic Convolutional Neu…

都说美国去工业化了,那美国人都做什么工作啊?

美国&#xff0c;这个全球经济的重要参与者&#xff0c;经历了一场深刻的变革——去工业化。这一过程意味着&#xff0c;曾经以制造业为荣的美国&#xff0c;逐渐将重心转移到了其他领域。那么&#xff0c;美国人都做什么工作呢&#xff1f;让我们走近这位“经济体巨人”&#…

Nginx企业级负载均衡:技术详解系列(17)—— 长连接优化策略与下载服务器高效搭建

你好&#xff0c;我是赵兴晨&#xff0c;97年文科程序员。 今天咱们来聊聊Nginx的两个知识点&#xff1a;Nginx的长连接优化、如何将Nginx配置成下载服务器。 长连接配置详解 在Nginx的配置中&#xff0c;长连接是一个重要的性能优化手段。它允许一个TCP连接上发送多个请求和…

centos7下安装MySQL,Oracle数据库

&#x1f4d1;打牌 &#xff1a; da pai ge的个人主页 &#x1f324;️个人专栏 &#xff1a; da pai ge的博客专栏 ☁️宝剑锋从磨砺出&#xff0c;梅花香自苦寒来 操作系统版本为CentOS 7 使⽤ MySQ…

“人工智能AI+” 应用场景盘点

在这个科技与梦想交相辉映的时代&#xff0c;人工智能已不再停留于遥不可及的概念构想&#xff0c;而是化身为一股汹涌的创新洪流&#xff0c;深刻塑造着社会的每一个角落。从文化艺术的智慧火花到生命科学的精密探索&#xff0c;从工业制造的革新升级到日常生活的细致入微&…

解决sd-webui中rembg插件使用报错问题

stable-diffusion-webui-rembg是我非常喜欢的sd-webui插件&#xff0c;PS抠图手残党的福音&#xff0c;一键抠图太爽啦。对于主体明确线条简单的图片&#xff08;如汽车、服饰简洁的人像等&#xff09;效果相当好&#xff1b;即便对于毛茸茸的对象&#xff08;如动物&#xff0…