- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第八章 符号表 符号表的作用 一致性检查和作用域分析; 辅助代码生成。 8.1 符号表的组织与作用 符号表的每一项(入口)包含两大栏: 名字栏,也称主栏,关键字栏; 信息栏,记录相应的不同属性,分为若干子栏。 对符号表的操作: 填入名称、查找名字、访问信息、修改信息、删除名字… 符号表:分类、组织… 对符号表进行操作的时机: 定义性出现; 使用性出现。 按名字的不同种属建立多张符号表,如:常数表、变量名表、过程名表… 符号的组织方式: 1.安排各项各栏的存储单元为固定长度; 2.用间接方式安排各栏存储单元。 符号表的存放次序 1.把每一项置于连续K存储单元中,构成一张K*N的表; 2.把整个符号表分成m个子表,如:T1、T2、…、Tm,每个子表含有N项。 符号表举例:PASCAL程序段: PROCEDURE INCWAP( M,N : INTEGER ); LABEL START; VAR K : INTEGER; BEGIN START: K := M + 1; M := N + 4; N := K; END. 8.2 整理和查找 1. 线性查找: 按关键字出现的顺序填写各项。 填表快,查找慢。 结构简单,节省空间,效率低,查找时间复杂度:O(n)。 改进:自适应线性表。 2. 二分查找: 表格中的项按名字的“大小”顺序排列。 填表慢,查找快。查找时间复杂度:O(Log2n) 。 改进:组织成二叉树。 3. 杂凑查找(HASH技术): 杂凑函数H(SYM):0~N-1 N:符号表的项数。 要求:1. 计算简单高效; 2. 函数值分布均匀。 填表快,查找快。 8.4 符号表的内容 符号表的信息栏中登记了每个名字的有关性质: 类型:整、实或布尔等; 种属:简单变量、数组、过程等; 大小:长度,即所需的存储单元字数; 相对数:指分配给该名字的存储单元的相对地址。 PL语言编译程序的符号表 1. 表格的定义: 名字表(nametab); 程序体表(btab); 层次显示表(display); 数组信息表(atab); 中间代码表(code)。 (1) 名字表(nametab) 名字表nametab:登记程序中出现的各种名字及其属性: (2) 程序体表btab 程序体表btab:记录一个程序体的总体信息,用于对源程序中定义的名字的作用域进行分析;对名字表进行管理。 层次显示表display 层次显示表display:描述正在处理的各个嵌套层次,对程序体表进行管理。 (3)数组信息表atab 8.3 名字的作用范围 在许多程序语言中,名字都有一个确定的作用范围。 两种程序体结构: 并列结构,如:FORTRAN; 嵌套结构,如:PASCAL,ADA。 FORTRAN程序举例 PROGRAM MAIN … integer X,Y COMMON /C/A,B … END SUBROUTINE SUB1 … real X,Z COMMON /C/A1,B1 … END PASCAL程序举例 program P; var a, b : integer; procedure P1(i1, j1 : integer); var c, d : integer … end; procedure P2(i2, j2 : integer); var a, c : integer; procedure P21; var b1, b2 : boolean; … end; … end; … end. 符号表的组织方式 1. FORTRAN语言的符号表组织: 一个FORTRAN程序由一个主程序段和若干个辅程序段组成。 把局部名和全局名分别存在不同的地方。 2. 嵌套结构语言的符号表组织: 如:PASCAL、ALGOL、ADA。名字的作用域遵循“最近嵌套原则”。 嵌套结构语言的符号表组织 两个方面的处理: 引入“过程编号”属性。在查找时,先查找本过程编号的名字,查不到则查找外层过程编号的名字,…,等等。 按“栈”式思想组织符号表。在查找时,从后往前查找,找到的第一个名字就是所需查找的名字。 PASCAL程序的符号表:举例 program P; var a, b : integer; procedure P1(i1, j1 : integer); var c, d : integer … end; procedure P2(i2, j2 : integer); var a, c : i
您可能关注的文档
最近下载
- 合作协议书(15篇)(模板) .pdf VIP
- 《电动汽车充电站设计规范》GB50966-2014(完整).docx VIP
- 网御星云网闸技术宝典.pdf VIP
- 江淮CPC(D)20-30-CPC(D)30A叉车零件图册.pdf VIP
- DB32T 3610.2-2025 道路运输车辆智能监控系统技术规范 第2部分:终端及测试方法.docx VIP
- 驾驶员的夜间行车视觉与夜间驾驶技巧.pptx VIP
- 中医临床三基(医师)临床基本知识针灸推拿考试真题.docx VIP
- GB50156-2012(2014年版) 汽车加油加气站设计与施工规范.pdf VIP
- 临近既有地铁的异形深基坑支护设计与施工.pdf VIP
- 《葡萄沟》精品课件.pptx VIP
文档评论(0)