编译原理符号表的原理及典型实例ppt课件
合集下载
编译原理符号表的原理及典型实例
05
符号表的设计与实现
符号表的数据结构设计
符号表的数据结构应满足高效、 易扩展和易维护的要求,通常 采用哈希表、二叉树等数据结
构实现。
符号表应包含符号名称、符 号类型、符号属性等信息, 以便在编译过程中快速查找
和识别符号。
符号表还应支持动态添加、删 除和修改等操作,以适应源代
码中符号的变化。
符号表的实现算法
常量名的符号表实例
总结词
常量名符号表实例展示了如何使用符号表来管理程序中的常量。
详细描述
常量名符号表记录了常量的名称、类型和值等信息。通过符号表,编译器能够方 便地查找常量的定义和使用,并进行相应的语义分析和代码生成。在处理常量时 ,符号表有助于编译器优化程序的性能,例如常量折叠和常量传播等。
04
编译原理符号表的原 理及典型实例
目录
• 编译原理符号表概述 • 符号表的原理 • 符号表的典型实例 • 符号表在编译过程中的应用 • 符号表的设计与实现
01
编译原理符号表概述
符号表的概念
符号表是一种用于存储程序中标识符 信息的数据结构,主要用于编译过程 中对标识符进行跟踪和管理。
符号表中的每个条目都包含有关标识 符的信息,如名称、类型、作用域等。
如果符号表中存在该标识符的信息,编译器就可以 使用这些信息来生成相应的代码。
符号表的更新
01
在编译过程中,符号表可能会被更新以反映源代码的变化。
02
当源代码中添加、删除或修改标识符时,符号表中的相关信息
也需要相应地更新。
更新符号表的过程通常涉及到在哈希表中插入、删除或修改相
03
应的条目。
03
符号表的典型实例
典型实例
编译原理精选版演示课件.ppt
预测分析表
3
表驱动的预测分析程序模型
khk
4
实现步骤:
(1) 判断文法是否为LL(1)文法。 如果文法中含有左递归,必须先消除 左递归
(2)构造预测分析表 : Select(A ) (3)列出预测分析过程
khk
5
第6章:自底向上分析方法
自底向上分析方法,也称移进归约分析法
实现思想(是推导的逆过程):
对输入符号串自左向右进行扫描,并将输入符逐个 移入一个后进先出栈中,边移入边分析,一旦栈顶 符号串形成某个句型的可归约串时,就用该产生式 的左部非终结符代替相应右部的文法符号串,称为 归约。重复这一过程,直到归约到栈中只剩下文法 的开始符号时,则分析成功。
关键问题
khk
6
移进—规约分析(Shift-reduce parsing)
+
A a
可得 b <. a
由A→( B 且B+ ( B… 可得 (<. (
+
B aa…
可得 (<. a
+
B Aa )
可得 (<. A
khk
18
A(B(Aa) …)
(3) 求> .关系:
A(B…B
+
Aa
由S→bAb,且A…) 可得 ) > . b
A+…B 可得 B > . b
khk
88
例1:文法
SaAcBe A b A Ab B d
输入串abbcde#分析
khk
9
归约分析过程(移进归约):
步骤 1 2 3 4 5 6 7 8 9 10 1kh1k
符号栈 # #a #ab #aA #aAb #aA #aAc #aAcd #aAcB #aAcBe #S
编译原理第八章 符号表
• 需要做作用域分析!
8.3 名字的作用范围(Fortran)
• Fortran 局部、全局
• 执行时过程(函数)不
Name
Information
嵌套,局部区域只有一
···
局
个现行段;
···
部 • 编译时,尽管查填符号
表过程只限于局部,但
考虑到地址分配的全局
性,需将每个程序段符
号表保存在外存中,采
• 定长方式 • 间接方式 (1)名字的间接存储 (2)信息的间接存储
Name ● ●
Information
如何组织
方式
6 S A MP L E 3 S U M
Name
Information ● ●
数组信息表 维数 首地址 维1
内情向量表
··· ···
以数组为例 维n
如何组织
• 对于名称:把所有标识符都存放在一个 独立的字符串数组,主栏只放一个指示 器和一个整数(名字的长度)
var f, g: real; procedure B3(y:real) const b=5; procedure B4 … end B4 end B3
end B2 end B1
8.3 名字的作用范围 (Pascal)
top
(14)…
B4 (13)…
0
h (12)… 13
sp b (11)…
12
y (10)…
最近使用优先查找 (链头)
较难
中 排序整理 折半查找
二叉树
较难
中 构造排序树,查找时 依子树次序逼近。
杂凑(哈希
难
表)
高 杂凑函数: 名称于位置的映射 基于计算的查找。
数据结构的知识
8.3 名字的作用范围(Fortran)
• Fortran 局部、全局
• 执行时过程(函数)不
Name
Information
嵌套,局部区域只有一
···
局
个现行段;
···
部 • 编译时,尽管查填符号
表过程只限于局部,但
考虑到地址分配的全局
性,需将每个程序段符
号表保存在外存中,采
• 定长方式 • 间接方式 (1)名字的间接存储 (2)信息的间接存储
Name ● ●
Information
如何组织
方式
6 S A MP L E 3 S U M
Name
Information ● ●
数组信息表 维数 首地址 维1
内情向量表
··· ···
以数组为例 维n
如何组织
• 对于名称:把所有标识符都存放在一个 独立的字符串数组,主栏只放一个指示 器和一个整数(名字的长度)
var f, g: real; procedure B3(y:real) const b=5; procedure B4 … end B4 end B3
end B2 end B1
8.3 名字的作用范围 (Pascal)
top
(14)…
B4 (13)…
0
h (12)… 13
sp b (11)…
12
y (10)…
最近使用优先查找 (链头)
较难
中 排序整理 折半查找
二叉树
较难
中 构造排序树,查找时 依子树次序逼近。
杂凑(哈希
难
表)
高 杂凑函数: 名称于位置的映射 基于计算的查找。
数据结构的知识
《编译原理》课件
了解中间代码生成的概念和它在编译过程中的角色。 学习四元式和三地址码的表示和生成方式,以及中间代码优化的技巧。
六、代码生成
了解目标机器的指令系统和存储结构,以及它们对代码生成的影响。 学习寄存器分配和目标代码生成的基本原理和方法。
七、附录
参考文献提供了进一步学习编译原理的资源。 课程总结将回顾课程中学到的重要知识,并概述关键概念和技术。 问题解答将回答学生在课程学习中提出的问题。 课程评价将收集学生对课程的反馈和评价,以便对将来的课程进行改进。
《编译原理》PPT课件
编译原理PPT课件将带您深入了解编译原理的重要概念和技术。这个课程介绍 了编译原理的意义以及编译过程的概述。
一、引言
课程介绍编译原理的重要性,让您理解为什么编译原理对于软件开发非常关 键。 编译过程的概述将带您了解传统的编译过程中涉及的各个阶段和任务。
二、词法分析
词法分析是编译过程中的第一步,了解词法分析的作用以及它在编译器中的 实现。 掌握正则表达式和有限自动机的概念,这些是实现词法分骤,理解它的作用和不同的语法分析方法。 学习上下文无关文法以及LL(1)语法分析器和LR(1)语法分析器的实现原理。
四、语义分析
语义分析是编译过程中的重要一环,了解它的作用和涉及的任务。 学习语义动作、符号表管理和类型检查,以及如何进行语法制导翻译。
五、中间代码生成
六、代码生成
了解目标机器的指令系统和存储结构,以及它们对代码生成的影响。 学习寄存器分配和目标代码生成的基本原理和方法。
七、附录
参考文献提供了进一步学习编译原理的资源。 课程总结将回顾课程中学到的重要知识,并概述关键概念和技术。 问题解答将回答学生在课程学习中提出的问题。 课程评价将收集学生对课程的反馈和评价,以便对将来的课程进行改进。
《编译原理》PPT课件
编译原理PPT课件将带您深入了解编译原理的重要概念和技术。这个课程介绍 了编译原理的意义以及编译过程的概述。
一、引言
课程介绍编译原理的重要性,让您理解为什么编译原理对于软件开发非常关 键。 编译过程的概述将带您了解传统的编译过程中涉及的各个阶段和任务。
二、词法分析
词法分析是编译过程中的第一步,了解词法分析的作用以及它在编译器中的 实现。 掌握正则表达式和有限自动机的概念,这些是实现词法分骤,理解它的作用和不同的语法分析方法。 学习上下文无关文法以及LL(1)语法分析器和LR(1)语法分析器的实现原理。
四、语义分析
语义分析是编译过程中的重要一环,了解它的作用和涉及的任务。 学习语义动作、符号表管理和类型检查,以及如何进行语法制导翻译。
五、中间代码生成
精品课程《编译原理》PPT课件第9章 符号表
RINFL[rp]:
域名部分 区距部分
FTP是域类型部分
一个记录类型要占几个RINFL表项, 不同记录类型所占表项个数不一,而 在表项中没有链接部分,因此在不同 记录的RINFL表之间可放置一条空项, 以表示记录类型的RINFL表中的结束。
综上所述,我们有: TYPEL表 integer: i
real: r b a
临时变量 局部变量 DISPLAY表 形式参数2 形式参数1 过函名 管理信息
l+ 1 5 4 3 0-2
抽象地址的变化规律可图示如下:
实在声明:
(l,off) <标号声明部分> (l,off) (l,off) <常量声明部分> (l,off) (l,off) <类型声明部分> (l,off)
在整个编译阶段都离不开符号表。 二、符号表的内容 0 Pascal 有以下几种类型: 整 型:integer 实 型:real 布尔型:boolean 数组型:ARRAY[N1…N2]OF T 记录型:RECORD id1:T1;…; idn;Tn END
类型表TYPEL结构形如: TCLASS
三、标识符的作用域与处理 程序段:PROGRAM…………………END 过程段:PROCEDURE………………END 函数段: FUNCTION………………END 记录类型: RECORD………………END
具体实现方法可分为两种: 真删除法
加标记法
9.4 抽象地址的处理
存储分配分为静态分配与动态分配。 在编译时分配的称静态分配。 在目标程序运行时分配的称动态分配。
2.若ICLASS.t=1,则IADDR是类型长度 3.若ICLASS.v=1.则IADDR是形如: LEVEL OFF 的抽象地址,其中LEVEL 是层数,OFF是区距部分。
编译原理课件-符号表
關鍵字域的組織
符號表的關鍵字域(段)就是符號名稱 等長關鍵字域(段)符號表 不等長關鍵字段符號表---採用關鍵字池的 索引結構。
作用域檢查 作用域和可見性
基本作用域規則(lexical rule) int a;
void Binky(int a) { int a; a = 2; ...
} 作用域檢查實現: 1每個作用域一個獨立的符號表,這些符號表組織成作用域
name:alfa; case kind: object of
constant: (val: integer); variable,procedur: (level, adr, size: integer) end;
例程式說明部分為:
CONST A=35,B=49;
Const(常量)無層次
VAR C,D,E;
VAL:35 VAL:49 LEVEL:LEV LEVEL:LEV LEVEL:LEV LEVEL:LEV LEVEL:LEV+1
ADR:DX ADR:DX+1 ADR:DX+2 ADR: ADR:DX
SIZE:4
…… ……
……
……
名字
類型
層次/值
地址 存儲空間
某編譯器的符號表實例
編譯程序分析第13行時符號表的內容
7.4 符號表
.符號表的作用和地位 .符號的主要屬性及作用 .符號表的組織
符號表的作用和地位-----語義檢查的依據
目標代碼生成階段地址分配的依據
在編譯程式中符號表用來存放語言程式中出現的有 關識別字的屬性資訊,符號表中所登記的資訊在 編譯的不同階段都要用到。
在語義分析中,符號表所登記的內容將用於語義檢 查(如檢查一個名字的使用和原先的說明是否一 致)和產生中間代碼。
编译原理课件第九章符号表
SUBROUTINE INCWAP(M,N) 10 K=M+1
M=M+4 N=K
RETURN
END
经编译头三阶段后所产生的主要表格有:符号 名表SNT、常数表CT、入口名表ENT、标号 表LT和四元式表QT
符号名表SNT
NAME (1)M (2)N (3)K
INFORMATION 哑元,整数,变量 哑元,整数,变量 整数,变量
在整个编译期间,对于符号表的操作大致可 归纳为五类:
• 对给定名字,查询名字是否已在表中;
• 往表中填入一个新的名字;
• 对给定名字,访问它的某些信息;
• 对给定名字,填写或更新它的某些信息;
• 删除一个或一组无用的项。
不同种类的表格所涉及的操作往往也是不同 的。上述五个方面只是一些基本的共同操 作。
.在符号表的信息栏中引入一个指针域(previous)用以链接它在同一过程内 的前一域名字在表中的下标(相对位置)。每一层的最后一个域名字,其 previous 之 值 为 0 。 这 样 , 每 当 需 要 查 找 一 个 新 名 字 时 , 就 能 通 过 DISPLAY找出当前正在处理的最内层的过程及所有外层的子符号表在栈 符号表中的位置。然后,通过previous可以找到同一过程内的所有被说明 的名字。
常Байду номын сангаас表CT
值(VALUE) (1) 1 (2) 4
入口名表ENT
NAME
INFORMATION
(1)INCWAP 二目子程序,入口QT(1)
/*记录入口名INCWAP的入口地址*/
标号表LT
LABLE INFORMATION
(1)10
QT(4)
/*记录了标号10对应的四元式序列号*/
M=M+4 N=K
RETURN
END
经编译头三阶段后所产生的主要表格有:符号 名表SNT、常数表CT、入口名表ENT、标号 表LT和四元式表QT
符号名表SNT
NAME (1)M (2)N (3)K
INFORMATION 哑元,整数,变量 哑元,整数,变量 整数,变量
在整个编译期间,对于符号表的操作大致可 归纳为五类:
• 对给定名字,查询名字是否已在表中;
• 往表中填入一个新的名字;
• 对给定名字,访问它的某些信息;
• 对给定名字,填写或更新它的某些信息;
• 删除一个或一组无用的项。
不同种类的表格所涉及的操作往往也是不同 的。上述五个方面只是一些基本的共同操 作。
.在符号表的信息栏中引入一个指针域(previous)用以链接它在同一过程内 的前一域名字在表中的下标(相对位置)。每一层的最后一个域名字,其 previous 之 值 为 0 。 这 样 , 每 当 需 要 查 找 一 个 新 名 字 时 , 就 能 通 过 DISPLAY找出当前正在处理的最内层的过程及所有外层的子符号表在栈 符号表中的位置。然后,通过previous可以找到同一过程内的所有被说明 的名字。
常Байду номын сангаас表CT
值(VALUE) (1) 1 (2) 4
入口名表ENT
NAME
INFORMATION
(1)INCWAP 二目子程序,入口QT(1)
/*记录入口名INCWAP的入口地址*/
标号表LT
LABLE INFORMATION
(1)10
QT(4)
/*记录了标号10对应的四元式序列号*/
《符号表简介》课件
保持搜索树的平衡性,提高查找性能。
3 缓存技术应用
4 优化算法实现
利用缓存技术减少查找次数,提高符号表 的访问速度。
通过使用更高效的数据结构和算法,提升 符号表的整体性能。
总结与展望
通过本次《符号表简介》的PPT课件,我们深入了解了符号表的定义与作用,常见数据结构及其应用, 代码实例演示,查找算法简介,动态符号表操作以及性能优化方法。希望本次课程能够为大家带来启发 与收获!
哈希查找
利用哈希函数将标识符映射到存储桶,实现 O(1)的平均查找时作
插入操作
将新的标识符和相关信息插入到符号表中的适当 位置。
删除操作
从符号表中删除指定的标识符和相关信息。
符号表性能优化方法
1 散列函数优化
2 搜索树平衡
设计高效的哈希函数,降低冲突和查找时 间。
3
Trie树
使用字典树的数据结构,实现对字符串的前缀匹配和查找操作。
符号表中的查找算法简介
简单查找
逐个比较标识符直到找到匹配项。时间复杂 度为O(n)。
平衡搜索树
通过平衡二叉搜索树结构,实现对有序符号 表的高效查找。
二分查找
对有序符号表进行查找,通过递归地分半查 找提高效率。时间复杂度为O(log n)。
《符号表简介》PPT课件
欢迎大家来到本次《符号表简介》的PPT课件!在本次课件中,我们将一起 探索符号表的定义与作用,常见数据结构及其符号表应用,以及代码实例演 示。让我们开始吧!
符号表的定义与作用
1 什么是符号表?
符号表是一种数据结构,用于存储和管理程序中的标识符及其关联信息。
2 符号表的作用
符号表在编程语言和编译器中起到关键作用,提供了标识符的唯一性、类型信息、内存 位置等。
《编译原理符号表》PPT课件
精选课件ppt
26
符号表的总体组织
属性3栏与属性4栏冗余,可将其合并;
增加了符号表管理和运行的复杂性,但减少了空间开销;
精选课件ppt
27
符号表的总体组织
总结:
为便于符号表的组织管理,每张符号表的表长通常为定 长是合理的;
每张符号表可以看作是一个多元组,每个元组由若干属 性组成,元组之间有相同的成员个数和一致的排列;
下推链域的组织
精选课件ppt
40
等长属性值域组织
可以取相应的数据类型表达属性值
符号布尔性质的属性域
defined 1(true) 表示已定义
defined 0(false) 表示未定义
表示符号的基本数据类型
Data-type 3个bit位(整型值)
Char
0 0 0 (0)
short
散列组织
对符号进行某种函数操作(杂凑函数)所得的函数值确 定它在符号表的位置;
Vhash = fhash(符号代码值)
改进:Lhash = mod(Vhash,N) ……….. …a…… ……..b.. …..a….. ……..d.. …c……. ……b….
精选课件ppt
33
符号表项的排列
▪ 函数外表示文件可视性,函数内表示所在函数可视;
动态存储区:生命周期是定义该变量的局部范围;
精选课件ppt
15
标识符符号的属性(信息)
具体位置:
按该变量在存储区类分别依出现先后的次序排列下 相对该存储区表头的相对位移量来表示的;
… Int a; …. float b; … Struct cc{
元组之间的区分由表项中“符号”一栏区分;
精选课件ppt
编译原理 符号表和词法分析PPT课件
地址码 数组的维数、下标 过程/函数参数 …...
三、储分配&符号表的组织
存储分配原则:(参见例P81) 1、标号、类型标识符和过程标识符不分配单元。
(1)标号对应机器语言是一个地址,不需要 分配单元。 (2)类型标识符定义了某种类型,不需要分 配单元。
(3)过程标识符没有值,也不需要分配单元。 2、常量、简单变量、数组、形参和函数等需要
识
var i,j,k:integer;
符 简单变量标识符 名字、类型、地址
的 属 性 数组标识符
var a:array[1..10]of integer;
名字、类型、维数、上下界、
下标类型、数据区首地址等
Procedure search(a:char);
过程/函数标识符 名字、形参、局部变量、过程/ 函数入口地址等
标识符的出现
定义性出现
填表
应用性出现
查表
五、符号表的结构和存取
符号表结构: 无序符号表 有序符号表 树结构符号表 栈符号表 hash表
六、词法分析
任务:
词法分析阶段:
扫描源程序的ASCII码序列,拼出每一个单词,并把每个 单词的ASCII码序列替换为所谓的机内表示TOKEN形 式(属性字),这时还检查词法错误。
分配单元。
三、存储分配&符号表的组织(续一)
静态分配:编译时能够确定所需存储空间的大小,并进行
存储分配。
1、同一分程序的不同分量分配在不同单元。 2、内外层中的不同量分配在不同的单元。
形参的分配。 eg. Procedure sum1(var sum:integer,I:integer); begin
一、符号表及其作用
1.编译程序逻辑图
三、储分配&符号表的组织
存储分配原则:(参见例P81) 1、标号、类型标识符和过程标识符不分配单元。
(1)标号对应机器语言是一个地址,不需要 分配单元。 (2)类型标识符定义了某种类型,不需要分 配单元。
(3)过程标识符没有值,也不需要分配单元。 2、常量、简单变量、数组、形参和函数等需要
识
var i,j,k:integer;
符 简单变量标识符 名字、类型、地址
的 属 性 数组标识符
var a:array[1..10]of integer;
名字、类型、维数、上下界、
下标类型、数据区首地址等
Procedure search(a:char);
过程/函数标识符 名字、形参、局部变量、过程/ 函数入口地址等
标识符的出现
定义性出现
填表
应用性出现
查表
五、符号表的结构和存取
符号表结构: 无序符号表 有序符号表 树结构符号表 栈符号表 hash表
六、词法分析
任务:
词法分析阶段:
扫描源程序的ASCII码序列,拼出每一个单词,并把每个 单词的ASCII码序列替换为所谓的机内表示TOKEN形 式(属性字),这时还检查词法错误。
分配单元。
三、存储分配&符号表的组织(续一)
静态分配:编译时能够确定所需存储空间的大小,并进行
存储分配。
1、同一分程序的不同分量分配在不同单元。 2、内外层中的不同量分配在不同的单元。
形参的分配。 eg. Procedure sum1(var sum:integer,I:integer); begin
一、符号表及其作用
1.编译程序逻辑图
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第三种组织法:折中方法
.
四、符号表的数据结构
线性表——符号表项按照符号被扫描到的先 后顺序登录
………………… …a…………… …………b…… …a…………… …………d…… …c…………… …………b…… ……
.
四、符号表的数据结构
有序表——符号表项按照符号的字符代码串 的值的大小排列
………………… …a…………… …………b…… …a…………… …………d…… …c…………… …………b…… ……
编译原理
.
第九章 符号表
.
第九章 符号表
在编译程序工作的过程中,需要不断收集、 记录和使用源程序中一些语法符号的类 型和特征等相关信息。这些信息一般以 表格形式存储于系统中。如常数表、变 量名表、数组名表、过程名表、标号表 等等,统称为符号表。
对于符号表组织、构造和管理方法的好 坏会直接影响编译系统的运行效率。
.
一、符号表的作用和功能
收集符号属性 上下文语义的合法性检查的依据 作为目标代码生成阶段地址分配的依据
例:C语言程序段:int a; a=1;
MOV #1,R0 MOV R0,mema
词法分析:a是一个单词; 语法分析:a出现在一条变量声明语句和一条赋 值语句中; 语义分析:a是一个整形符的名字 与标识符有关的信息
类型信息(包括种类和属性) 地址码 层次信息 行号信息 ……
.
二、符号表的内容
例:Pascal语言的名字信息表nametab
name kind lev typ normal ref adr/val/size link
0 1 tx→
当组在名信程名字息序▪中址▪▪avs字名(类a分为表di体zclre,,类o,当字型当数中表标当的n名名 (于名名c存种(组的s字字tbh一 名 其识字字无贮ty为为ta类位a为p单a,个变他n变的类r符e类名 定 义b元,置型s量t量指在n为)型))当布情的)类型、a名中、主字的名、可或;名向n0相m时时名尔况型的a过时的对变程所层布同以数当e,m(包,地t字量填,名程填a位量序在次一e尔是括名组填址b入t是,入字类形a入程(;中置(的的为型常他字变pbv参该对用否t序填型们登中ra;层程2r,(类量为于ourb的.,体于为记的存有入型ci过其序次eo相a过名e入数中程的位依或bo变标应整nd他体为该据名程时l定o值第置ue)次不变量明所型,、情t的1)r义名,一,量y需填、e类,填名形(p数(况存静的入)i个每或时rne推主e贮字参他形上组名个rt态f,单s们e参指程是名一字程)(元f相层)r、a为在向的序个e应否时的序r相次fr数字代0名该指l体a中应为填i目码。ny符活字在向数k的定s变入动规入)型组该记,量f口a录在地过对l形se数程参,
{ int b=1; { int a=2; printf(“%d,%d\n”,a,b); } { int b=3; printf(“%d,%d\n”,a,b); } printf(“%d,%d\n”,a,b); }
printf(“%d,%d\n”,a,b); }
B2的符号表
a
B3的符号表
b
ax→
数组的数下组标元类素型类型当元元素数素数组为组下数信数数限组息组组数在时上元组,at限素a本它b的身指表体的向中积体该积 的位置,其他情况为0
.
type a=array[1..10, 1..10] of integer;
name kind typ ref
k a type arrays n
nametab
.
三、符号表的组织
假设有下列三类符号及其所需属性
第一类符号 属性1 属性2 属性3 第二类符号 属性1 属性2 属性4 第三类符号 属性2 属性5 属性6
第二种组织法:单一组织 优点:管理一致,集中单一 缺点:管理复杂
.
三、符号表的组织
假设有下列三类符号及其所需属性
第一类符号 属性1 属性2 属性3 第二类符号 属性1 属性2 属性4 第三类符号 属性2 属性5 属性6
.
四、符号表的数据结构
散列表——符号表项的位置由对该符号进行 某种函数操作所得到的函数值来确定
………………… …a…………… …………b…… …a…………… …………d…… …c…………… …………b…… ……
.
五、符号表与作用域
int main()
{
int a=0;
int b=0;
{
int b=1;
根据符号属性相似程度分类组织成若干 张表,每张表中记录的符号都有比较多 的相同属性。
.
三、符号表的组织
假设有下列三类符号及其所需属性
第一类符号 属性1 属性2 属性3 第二类符号 属性1 属性2 属性4 第三类符号 属性2 属性5 属性6
第一种组织法:按属性分类
优点:管理一致,空间效率高 缺点:管理复杂
{
int a=2;
B2
printf(“%d,%d\n”,a,b);
}
B0
B1
{
B3
}
int b=3; printf(“%d,%d\n”,a,b);
printf(“%d,%d\n”,a,b);
}
printf(“%d,%d\n”,a,b);
}
.
NULL
a b
B0的符号表
B1的符号表
b
.
int main() {int a=0; int b=0;
tx→
inxtyp eltyp elref low high elsize size
atab
n ints arrays m 1 10 10 100
m ints ints 0 1 10 1 10
ax→
.
三、符号表的组织
按照属性种类完全相同的那些符号组织 在一起;
把所有语言中的符号都组织在一张符号 表中;
二、符号表的内容 例:Pascal语言的名字信息表nametab
type a=array[1..10, 1..10] of integer;
name kind typ ref
k a type arrays n
nametab
tx→
.
二、符号表的内容
例:Pascal语言的数组信息表atab
inxtyp eltyp elref low high elsize size 1 2
.
四、符号表的数据结构
线性表——符号表项按照符号被扫描到的先 后顺序登录
………………… …a…………… …………b…… …a…………… …………d…… …c…………… …………b…… ……
.
四、符号表的数据结构
有序表——符号表项按照符号的字符代码串 的值的大小排列
………………… …a…………… …………b…… …a…………… …………d…… …c…………… …………b…… ……
编译原理
.
第九章 符号表
.
第九章 符号表
在编译程序工作的过程中,需要不断收集、 记录和使用源程序中一些语法符号的类 型和特征等相关信息。这些信息一般以 表格形式存储于系统中。如常数表、变 量名表、数组名表、过程名表、标号表 等等,统称为符号表。
对于符号表组织、构造和管理方法的好 坏会直接影响编译系统的运行效率。
.
一、符号表的作用和功能
收集符号属性 上下文语义的合法性检查的依据 作为目标代码生成阶段地址分配的依据
例:C语言程序段:int a; a=1;
MOV #1,R0 MOV R0,mema
词法分析:a是一个单词; 语法分析:a出现在一条变量声明语句和一条赋 值语句中; 语义分析:a是一个整形符的名字 与标识符有关的信息
类型信息(包括种类和属性) 地址码 层次信息 行号信息 ……
.
二、符号表的内容
例:Pascal语言的名字信息表nametab
name kind lev typ normal ref adr/val/size link
0 1 tx→
当组在名信程名字息序▪中址▪▪avs字名(类a分为表di体zclre,,类o,当字型当数中表标当的n名名 (于名名c存种(组的s字字tbh一 名 其识字字无贮ty为为ta类位a为p单a,个变他n变的类r符e类名 定 义b元,置型s量t量指在n为)型))当布情的)类型、a名中、主字的名、可或;名向n0相m时时名尔况型的a过时的对变程所层布同以数当e,m(包,地t字量填,名程填a位量序在次一e尔是括名组填址b入t是,入字类形a入程(;中置(的的为型常他字变pbv参该对用否t序填型们登中ra;层程2r,(类量为于ourb的.,体于为记的存有入型ci过其序次eo相a过名e入数中程的位依或bo变标应整nd他体为该据名程时l定o值第置ue)次不变量明所型,、情t的1)r义名,一,量y需填、e类,填名形(p数(况存静的入)i个每或时rne推主e贮字参他形上组名个rt态f,单s们e参指程是名一字程)(元f相层)r、a为在向的序个e应否时的序r相次fr数字代0名该指l体a中应为填i目码。ny符活字在向数k的定s变入动规入)型组该记,量f口a录在地过对l形se数程参,
{ int b=1; { int a=2; printf(“%d,%d\n”,a,b); } { int b=3; printf(“%d,%d\n”,a,b); } printf(“%d,%d\n”,a,b); }
printf(“%d,%d\n”,a,b); }
B2的符号表
a
B3的符号表
b
ax→
数组的数下组标元类素型类型当元元素数素数组为组下数信数数限组息组组数在时上元组,at限素a本它b的身指表体的向中积体该积 的位置,其他情况为0
.
type a=array[1..10, 1..10] of integer;
name kind typ ref
k a type arrays n
nametab
.
三、符号表的组织
假设有下列三类符号及其所需属性
第一类符号 属性1 属性2 属性3 第二类符号 属性1 属性2 属性4 第三类符号 属性2 属性5 属性6
第二种组织法:单一组织 优点:管理一致,集中单一 缺点:管理复杂
.
三、符号表的组织
假设有下列三类符号及其所需属性
第一类符号 属性1 属性2 属性3 第二类符号 属性1 属性2 属性4 第三类符号 属性2 属性5 属性6
.
四、符号表的数据结构
散列表——符号表项的位置由对该符号进行 某种函数操作所得到的函数值来确定
………………… …a…………… …………b…… …a…………… …………d…… …c…………… …………b…… ……
.
五、符号表与作用域
int main()
{
int a=0;
int b=0;
{
int b=1;
根据符号属性相似程度分类组织成若干 张表,每张表中记录的符号都有比较多 的相同属性。
.
三、符号表的组织
假设有下列三类符号及其所需属性
第一类符号 属性1 属性2 属性3 第二类符号 属性1 属性2 属性4 第三类符号 属性2 属性5 属性6
第一种组织法:按属性分类
优点:管理一致,空间效率高 缺点:管理复杂
{
int a=2;
B2
printf(“%d,%d\n”,a,b);
}
B0
B1
{
B3
}
int b=3; printf(“%d,%d\n”,a,b);
printf(“%d,%d\n”,a,b);
}
printf(“%d,%d\n”,a,b);
}
.
NULL
a b
B0的符号表
B1的符号表
b
.
int main() {int a=0; int b=0;
tx→
inxtyp eltyp elref low high elsize size
atab
n ints arrays m 1 10 10 100
m ints ints 0 1 10 1 10
ax→
.
三、符号表的组织
按照属性种类完全相同的那些符号组织 在一起;
把所有语言中的符号都组织在一张符号 表中;
二、符号表的内容 例:Pascal语言的名字信息表nametab
type a=array[1..10, 1..10] of integer;
name kind typ ref
k a type arrays n
nametab
tx→
.
二、符号表的内容
例:Pascal语言的数组信息表atab
inxtyp eltyp elref low high elsize size 1 2