《编译原理蒋宗礼课件第8章.ppt

  1. 1、本文档共29页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第8章?符号表管理 8.1 符号表的作用 8.2 符号表中存放的信息 8.3 符号表的组织结构 8.4 符号表与作用域 8.5 本章小结 8.1 符号表的作用 编译的各个阶段都有可能会用到符号表中登记的信息 协助进行语义检查(如检查一个名字的引用和之前的声明是否相符)和中间代码生成 在目标代码生成阶段,当需要为名字分配地址时,符号表中的信息将是地址分配的主要依据 编译器用符号表来记录、收集和查找出现在源程序中的各种名字及其语义信息。 8.1 符号表的作用 符号表是以名字为关键字来记录其信息的数据结构,其上支持的两个最基本操作应该是填加表项和查找表项,这两个操作必须是高效的 8.2 符号表中存放的信息 记录源程序中出现的各种名字及其属性信息是符号表的首要任务。 显然同一个名字在一段程序中应该表示同一个对象,即同一个符号表中不能出现相同的名字,因此名字可以作为符号表的关键字。于是,每一个符号表表项中需要存放的基本信息就是符号的名字及其属性 。 8.1.1 符号表中的名字 名字字段长度固定 名字项的长度大小取决于标识符允许的最大长度 不适于标识符长度变化范围较大的语言 空间浪费 名字字段长度可变 标识符的长度没有限制 符号表上的操作复杂而低效 引入一个单独的字符串表,将符号表中的全部标识符集中放在这个字符串表中,而在符号表表项的名字部分只要给出相应标识符的首字符在字符串表中的位置即可 8.1.1 符号表中的名字 8.1.1 符号表中的名字 8.1.1 符号表中的名字 8.1.2 符号表中的属性 符号所表达的含义不同,符号表中需要存放的属性也就不同 数组名字需要存放的属性信息应该包括数组的维数、各维的维长等 函数(或过程)的名字应该存放其参数个数、各参数的类型、返回值的类型等 8.1.2 符号表中的属性 建立多个符号表来管理源程序中出现的各种符号,如常数表、变量表、函数表、数组表等 可能出现不同种类符号出现重名的问题 建立一张共用的大表来管理各种符号,此时需要在符号表中增设一个标志来表明符号的种属 不同种类符号所需存放属性信息在数量上的差异将会造成符号表的空间浪费 8.1.2 符号表中的属性 8.1.2 符号表中的属性 8.1.3 符号的地址属性 如果采用静态存储分配策略,则符号x绑定的地址等于静态分配的基址base加上符号x的偏移量offset 如果采用的是栈式存储分配或堆式存储分配等动态分配策略,则符号是在程序执行过程中和地址动态绑定的。 如栈式存储分配时,i的地址是以栈指针sp为基址加上i相对于活动记录起始地址的偏移量offseti 符号表中各符号的地址属性就是该符号相对于第一个符号的偏移地址 8.3 符号表的组织结构 8.3.1 符号表的线性表实现 用线性表实现符号表较为直观 数组实现:插入n个符号、执行e次查找操作的时间复杂度为T(n, e) = O(n(n+e)) 有序数组实现:插入n个符号、执行e次查找操作的时间复杂度为T(n, e) = e?log n+ + ≤ (n+e)log n+O(n2) 有序符号表结构只有在下面的情况下才能取得较好效果:和插入操作次数相比,符号表表项上的查找操作次数占绝对多数,即en。 8.3.2 符号表的散列表实现 引入散列表不仅可以提高lookup操作的效率,同时也可以提高insert操作的效率,所以在许多实际编译器的符号表实现中均采用了散列技术 8.3.2 符号表的散列表实现 引入散列表不仅可以提高lookup操作的效率,同时也可以提高insert操作的效率,所以在许多实际编译器的符号表实现中均采用了散列技术 插入n个符号,查找e个符号的lookup操作和insert操作的时间复杂度T(n,e)还将与m有关,记为T(n,e,m) ,T(n,e,m)≈n(n+e)/m S(n,m)=O(n) 散列函数应在满足 的前提下,使 达到最小 8.4 符号表与作用域 int main() { int abc; abc = 1; { int abc; abc = 2; printf(“abc is %d\n”, abc); } printf(“abc is %d\n”, abc); } 8.4.1 程序块结构的符号表 变量的作用域满足最近嵌套原则 (1) int main() (2) { (3) int a=0; (4) int b=0; (5) { (6) int b=1; (7) { (8) int a

文档评论(0)

you9391 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档