当前位置: 首页 > java >正文

编译原理-10-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综合属性的动作放在产生式体的最右边

http://www.xdnf.cn/news/11315.html

相关文章:

  • 深度强化学习及其在军事领域中的应用综述
  • 需求管理的主要内容包括哪些
  • 如何配置JDK
  • 2024年最全AutoRuns下载安装使用教程(图文教程)超详细,成功入职阿里
  • 2024年运维最新Linux系统的web管理工具——webmin搭建,2024年最新蚂蚁金服内推四面
  • 深入理解计算机系统(CSAPP)含lab详解 完结
  • 聚类(clustering)与分类(Classification)的区别
  • C语言之scanf/sprintf、fscanf/fprintf、sscanf/sprintf、snprintf
  • Java 7的七大新功能
  • String index out of range: 100 报错详解
  • 虚拟机下载安装及其一些指令(VMware)
  • 守护进程
  • 对称加密与非对称加密
  • 一区即将要洗的DVD片子
  • 【安全】简单解析统一身份认证:介绍、原理和实现方法
  • 一文搞懂程序流程图详解
  • 使用webrtc-streamer查看实时监控
  • js常用四舍五入方法
  • caffe的用法
  • Mint UI - 饿了么出品的开源、轻量的移动端 UI 组件库
  • SecureCRT 64位安装与破解
  • 【并发编程】 --- CyclicBarrier原理简介 + 使用方法
  • C语言入门到精通,这一篇就够了(13万字笔记)
  • 【集合篇】Java集合概述
  • 主流压缩软件压缩率实测(图文详解,揭秘你不知道的)
  • little-loader 开源项目教程
  • 2、CSS 文本
  • canvas的drawImage方法参数详解
  • 【STK】手把手教你利用STK进行仿真-STK软件简介01STK基本模型
  • openlayers [四] 地图图层 Layers详解