编译原理-17-SDT

2024-03-15 18:10
文章标签 编译 原理 17 sdt

本文主要是介绍编译原理-17-SDT,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Sematics2-SDT

1. Definition (语法制导的翻译方案(Syntax-Directed Translation Scheme;SDT))

SDT是在其产生式体中嵌入语义动作的上下文无关文法。

  1. 语义动作可以嵌入在产生式体中的任何地方

上图中表示满足生成式后执行操作

  1. 上图中第2和4条表示先打印再匹配
  2. 前缀表达式SDT
    1. 语义动作嵌入的位置决定了何时执行该动作
    2. 基本思想: 一个动作在它左边的所有文法符号都处理过之后立刻执行

1.1. 时机

  1. Q:如何将SDD中的语义规则转换为带有语义动作的SDT

  1. Q:如何以三种方式实现SDT?

1.1.1. Offline 方式: 已有语法分析树

  1. 按照从左到右深度优先顺序遍历语法分析树
  2. 基本思想: 一个动作在它左边的所有文法符号都处理过之后立刻执行

1.1.2. 嵌入语义动作虚拟节点的语法分析树

语义动作也可以作为一个节点


  1. 基本思想:一个动作在它左边的所有文法符号都处理过之后立刻执行
  2. Q:是否所有的SDT都可以在LL/LR语法分析过程中实现

1.1.3. 该SDT无法在LL(1)/LR(1)中实现

  1. 前缀表达式SDT它需要在还不知道出现在输入中的运算符号是∗还是+时,就执行打印这些符号的操作

  1. Q::如何判断某SDT是否可以在LL/LR语法分析过程中实现?
  2. 将每个内嵌的语义动作A替换为一个独有的非终结符M,添加新产生式M→ε,判断新产生的文法是否可用LL/LR进行分析

1.2. 前缀表达式SDT

M 2 → ϵ M 4 → ϵ M 7 → ϵ \begin{array}{l} M2 \rightarrow \epsilon \\ M4 \rightarrow \epsilon \\ M7 \rightarrow \epsilon \\ \end{array} M2ϵM4ϵM7ϵ

M 2 → ⋅ , ( / d i g i t M2 \rightarrow ·,(/digit M2,(/digit是通过计算 F i r s t ( E ) First(E) First(E)得到的

2. SDT

2.1. 后缀翻译方案

  1. 后缀翻译方案:所有动作都在产生式的最后在LR中,按某个产生式归约时,执行相应动作

  1. 移入时,携带终结符的属性
  2. 归约时,计算A的属性值并入栈

2.2. L属性定义与LL语法分析

A → X 1 ⋅ ⋅ ⋅ X i ⋅ ⋅ ⋅ X n A \rightarrow X_1···X_i···X_n AX1XiXn

  1. 原则:从左到右处理各个Xi符号对每个Xi,先计算继承属性,后计算综合属性

2.3. 递归下降子过程 A → X 1 ⋅ ⋅ ⋅ X i ⋅ ⋅ ⋅ X n A \rightarrow X_1···X_i···X_n AX1XiXn

  1. 在调用 X i X_i Xi子过程之前,计算 X i X_i Xi的继承属性
  2. X i X_i Xi的继承属性为参数调用 X i X_i Xi子过程
  3. X i X_i Xi子过程返回之前,计算 X i X_i Xi的综合属性
  4. X i X_i Xi子过程中返回 X i X_i Xi的综合属性

X . x X.x X.x表示的是 X X X的综合属性,以此类推

2.4. 继承属性R.i用于计算并传递中间结果

  1. 先计算继承属性,再计算综合属性

原则:继承属性在处理文法符号之前,综合属性在处理文法符号之后

开始节点不可能有继承属性

3. L属性定义转换为SDT

A → X 1 ⋅ ⋅ ⋅ X i ⋅ ⋅ ⋅ X n A \rightarrow X_1···X_i···X_n AX1XiXn

  1. 计算 X i X_i Xi继承属性的动作放在产生式体中 X i X_i Xi左边
  2. 计算产生式头部 A A A综合属性的动作放在产生式体的最右边

这篇关于编译原理-17-SDT的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu

hdu4059容斥原理

求1-n中与n互质的数的4次方之和 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWrit