编译原理 笔记

这篇博客详细梳理了编译原理的语法分析,包括自顶向下和自底向上的方法,如LL(1)、LR(0)等。还深入讲解了语法制导翻译,涵盖SDD、L属性定义、SDT及其应用,并介绍了中间代码生成和运行存储分配的相关概念。
摘要由CSDN通过智能技术生成

面向考试的编译复习笔记。

U4 语法分析(包含4~7讲)

  1. 自顶向下方法 只介绍了LL(1)文法,这个其实就是预测分析法。核心思想就是根据下一个输入的字符,决定采用哪个产生式进行推到。自顶向下分析过程称为推导。

第一个“L”表示从左向右扫描输入
第二个“L”表示产生左推导
“1”表示在每一步中只需要向前看一个输入符号来决定语法分析动作

  1. 自底向上分析 介绍了LR(0)、SLR(1)、LR(1)、LALR。
    拿到了识别活前缀的DFA图,构建LR分析表:
    1.1 对于待约项目和移入项目,大家的操作都是一样的。
    1.2 对于规约项目,大家具有不同的操作:
    ① LR(0)对于所有的非终结符,都采取规约的操作;
    ② SLR(1)仅对于该规约项目的左部的FOLLOW集中的非终结符采取规约操作;
    ③ LR(1)仅对于该规约项目的搜索符集中的非终结符采取规约操作。

L:从左向右扫描输入字符串
R:自底向上规约,使用的是最左规约,也就是反向的最右推导
K:向前看K个字符,K=1时省略


U5 语法制导翻译(包含8~10讲)

5-1 语法制导翻译概述

5-2 语法制导定义SDD

5-3 SDD求值顺序

  1. 依赖图

5-4 S属性定义和L属性定义

  1. S属性SDD=S属性定义=S-SDD:仅使用综合属性。适用于自底向上语法分析。
  2. L属性SDD=L属性定义=L-SDD:可以有综合属性,也可以有继承属性(但是继承属性必须是自己的、左兄弟节点的或者是父节点的)。
  3. 有上可知,L-SDD包含S-SDD。

5-5语法制导翻译方案SDT

  1. SDT可以看作是SDD的具体实现方案
  2. 将S-SDD转换为SDT:这个较为简单,因为S属性定义中,所有的属性值都是综合属性
⒈ 题目 分析对象的BNF定义如下: 〈算术表达式〉∷=〈项〉|〈算术表达式〉+〈项〉|〈算术表达式〉-〈项〉 〈项〉∷=〈因式〉|〈项〉*〈因式〉|〈项〉/〈因式〉 〈因式〉∷=〈变量〉│(〈算术表达式〉) 〈变量〉∷=〈字母〉 〈字母〉∷=A|B|C|D|E|F|G|H|I|J|K|L|M|N|O|P|Q|R|S|T|U|V|W|X|Y|Z (a)总程序过程 (b) ( E过程)算术表达式处理 (c)项处理(T过程) (d)因式处理过程)(F过程) (e) (f) 图2-7-5 递归下降法分析表达式之框图 (a) ZC 过程;(b) E 过程;(c) T 过程; (d) F 过程;(e) 函数过程 SYM ;(f) 过程 ADVANCE ⒉ 算法 用递归下降法分析上述算术表达式的框图,如图2-7-5所示。这里,ZC过程为总控程序,主要完成: ⑴ 通知外界键入算术表达式; ⑵ 控制E过程分析算术表达式; ⑶ 根据分析结果之正误,分别通知外界不同的信息。 ZC过程被设计成可以分析无穷多个算术表达式。E、T和F三个过程分别对应〈算术表达式〉、〈项〉和〈因式〉三个产生式的处理。它们用到两个公共过程。一个是函数过程SYM,它负责从输入字符串ST中取出下一个字符,并存入SYM中等待分析。另一个过程ADVANCE负责剔除ST中的首字符。 算法的书写和实现也请参考课堂教学所给出的方法和实例,不一定照搬以上的框图。 ⒋ 小结 ⑴ 实习前的准备 按实习目的和要求,用PASCAL语言编写一个语法分析程序,同时考虑相应的数据结构。 ⑵ 调试 调试例子应包括符合语法规则的算术表达式,以及分析程序能够判别的若干错例。 ⑶ 输出 对于所输入的算术表达式,不论对错,都应有明确的信息告诉外界。 ⑷编写上机实习报告。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值