第八章 符号表 符号表的作用: 一致性检查和作用域分析; 辅助代码生成..

Slides:



Advertisements
Similar presentations
一、模型与计算公式 二、基本的组合分析公式 三、概率直接计算的例子 第 1.3 节 古典概率 四、抽签与顺序无关 五、二项分布与超几何分布 六、概率的基本性质.
Advertisements

邱锡鹏 复旦大学计算机科学技术学院 Text Books  “Dragon book”  Compilers: Principles, Techniques, and Tools (2nd Edition)  Alfred V. Aho;Monica S.
证券市场基础知识真题.
說 劍 《莊子‧雜篇》─ 第 一 組 賴泊錞 謝孟儒 張維真 羅苡芸
大學入學考試中心 九十六學度學科能力測驗試題 國文科 -哈利波特番外篇-
藥物濫用 華德學校上午校 黃秀雯.
第十六专题 近代以来世界的科学 技术和文学艺术
第二章 复式记账原理*** 主要内容、重点难点: 1.会计要素与会计等式*** 2.会计科目与账户*** 3. 借贷记账法***
探索确定位置的方法 王积羽.
第二单元 生产、劳动与经营.
第四章 控制结构.
搜索与回朔算法 搜索与回朔是计算机解题中常用的算法,很多无法根据某种确定的计算法则来求解的问题,可以利用搜索与回朔方法求解。它的基本思想是:为了求得问题的解,先选择某一种可能情况向前探索,在探索的过程中,一旦发现原来的选择是错误的,就退回一步重新选择,然后再继续向前探索,如此反复进行,直到得到解或证明无解为止。
1、分别用双手在本上写下自己的名字 2、双手交叉
第三课 走向自立人生.
黃金比例.
2016届高三期初调研 分析 徐国民
2007年11月考试相关工作安排 各考试点、培训中心和广大应考人员:
綜合所得稅基本介紹 財政部南區國稅局新化稽徵所 簡秀珍.
分式的乘除(1) 周良中学 贾文荣.
忠孝國小自立午餐老師的叮嚀 教師指導手冊.
第四章 制造业企业 主要经济业务核算.
数据结构(C语言版) Data Structure
《思想品德》七年级下册 教材、教法与评价的交流 金 利 2006年1月10日.
财经法规与会计职业道德 (3) 四川财经职业学院.
2 分子的热运动.
上課囉 職場甘苦談 小資男孩向錢衝 育碁數位科技 呂宗益/副理.
课标教材下教研工作的 实践与思考 山东临沂市教育科学研究中心 郭允远.
第八章二元一次方程组 8.3实际问题与二元一次方程组.
第八章二元一次方程组 8.3实际问题与二元一次方程组 (第3课时).
第 二 课 程序组成、基本数据类型、表达式 我们以上一章练习题为例说明Pascal程序的结构形式:
第9章 运行时的存储组织 重点:符号表的内容、组织,过程调用实现, 难点:参数传递,过程说明语句代码结构,
一、单选题 1、 字符串“ababacbab”和字符串“abcba”的最长公共子串是( )。
ASP VBScript 基础知识.
Chapter 模組 台灣師範大學數學系 黃聰明.
陳維魁 博士 儒林圖書公司 第七章 參數的傳遞 陳維魁 博士 儒林圖書公司.
程式語言 -Visual Basic 變數、常數與資料型態.
第四章 程序设计初步 顺序结构:赋值语句、输出语句
6 下标变量的中间代码生成 下标:数组;变量: 下标变量:即数组分量: 简单变量:id,其地址可查到;
欢迎参加VHDL培训 VHDL培训教程 浙江大学电子信息技术研究所 电子设计自动化(EDA)培训中心
第10章 子定型 子定型是类型上的一种关系,该关系隐含一个类型的值可以代替另一个类型的值
第4章 程序控制结构与算法基础.
Chapter 2 Basic Elements of Fortran
编译原理实践 5.给定语法的语法分析程序构造.
第4章 常量和变量 常量和变量都是程序中预留的用于保存数据的内存空间。常量的值在程序运行过程中始终不会发生变化。而变量的值在程序的运行过程中是可以变化的。在Fortran语言中,有五种基本的数据类型可供使用。他们分别是整型(INTEGER)、实型(REAL)、复型(COMPLEX)、字符型(CHARACTER)和逻辑型(LOGICAL)。按用途,又可以分数值型、字符型和逻辑型三种。相应的常量和变量也可以分为这三种。本章将按照用途介绍常量和变量的基本概念。
中间代码生成.
第2章 PL/0编译程序 2.1 PL/0语言和类pcode的描述 2.2 PL/0编译程序的结构 2.3 PL/0编译程序的语法语义分析
第六章 安全衛生工作守則 6-1 前 言  6-2 訂定依據相關法令規定  6-3 工作守則製作程序及製作前應注意事項  6-4 如何訂定適合需要之安全衛生工作守則  6-5 結 論.
陳維魁 博士 儒林圖書公司 第五章 控制結構 陳維魁 博士 儒林圖書公司.
动态规划(一).
语义分析概述 符号表 第六章 语义分析.
最大公约数 ——解题报告 作者:宋含章 七(12)班 1.
RAPTOR流程圖編程 介紹 和 變量 中三級.
江西财经大学信息管理学院 《数据库应用》课程组2007
编译原理实践 11.语义分析与代码生成.
Chapter 指標.
苏 教 版 五 年 级 数 学(上) 用字母表示数 青阳体仁小学 胡春雅.
第二章、第三章错题分析.
陳維魁 博士 儒林圖書公司 第三章 變數與繫結 陳維魁 博士 儒林圖書公司.
第3 语言翻译问题 [学习目标]:学习和掌握语言的语法的基本概念和基本要素,理解翻译的步骤;学习和掌握BNF文法。
第九章 运行时存储空间组织 网上教学系统: : 编译原理
中五級電腦科 PASCAL檔案處理.
本节内容 Lua基本语法.
苏教版五年级数学上册 用含有字母的式子表示 简单的数量关系 周冬妮 1.
問題解決與流程圖 高慧君 台北市立南港高中 2006年12月22日.
第十章 汽车的使用寿命.
三 顺序结构程序设计 厦大附中信息技术.
PASCAL语言 吉林大学计算机科学与技术学院.
PASCAL语言 吉林大学计算机科学与技术学院.
陳維魁 博士 儒林圖書公司 第六章 領域與範圍 陳維魁 博士 儒林圖書公司.
编译原理 中南大学软件学院 陈志刚.
Presentation transcript:

第八章 符号表 符号表的作用: 一致性检查和作用域分析; 辅助代码生成.

8.1 符号表的组织与作用 符号表的每一项(入口)包含两大栏: 对符号表的操作: 名字栏,也称主栏,关键字栏 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.

PROCEDURE INCWAP(M,N:INTEGER); LABEL START; VAR K:INTEGER; BEGIN START: K:=M+1; M:=N+4; N:=K; END.

PROCEDURE INCWAP(M,N:INTEGER); LABEL START; VAR K:INTEGER; BEGIN START: K:=M+1; M:=N+4; N:=K; END.

PROCEDURE INCWAP(M,N:INTEGER); LABEL START; VAR K:INTEGER; BEGIN START: K:=M+1; M:=N+4; N:=K; END.

PROCEDURE INCWAP(M,N:INTEGER); LABEL START; VAR K:INTEGER; BEGIN START: K:=M+1; M:=N+4; N:=K; END.

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)。 8.2 整理和查找 1. 线性查找 按关键字出现的顺序填写各项。 填表快,查找慢。 结构简单,节省空间,效率低,查找时间复杂度:O(n)。 改进:自适应线性表

表格中的项按名字的“大小”顺序整理排列。 填表慢,查找快。查找时间复杂度:O(Log2n) 改进:组织成二叉树。 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:登记程序中出现的各种名字及其属性 Kind, 名字种类,可以是常量(constant)、变量(variable)、类型(type)、过程(procedure) leve, 名字所在的程序体的静态层次。规定主程序的层次为1,主程序中定义的层次为2,依次类推 type, 名字的类型,类型有整型(ints)、字符型(chars)、布尔型(bool)、数组(arrays),对于无类型的名字填入notype ref, 当名字为数组类型或数组变量名时,ref指向该数组在数组信息表中的位置;当名字为过程名时,ref指向该过程在程序体表(btab)中的位置;其他情况ref为0 normal, 一个布尔量,用于标明名字是否为变量形参名,当名字是否为变量形参名时填入false,其他情况填入true或不填 adr, 当名字为变量名时(包括形参),存入该变量(或形参)在相应活动记录中分类的存贮单元的相对地址;对于过程名,填入他们相应代码的入口地址 val, 当名字为变量名时,填入他们的相应值 size, 当名字为类型名时,填入该类型数据所需存贮单元的数目 link, 指向同一程序体中定义的上一个名字在nametab中的位置,每个程序体在nametab中登记的第一个名字的link为0 名字所在的程序体的静态层次。规定主程序的层次为1,主程序中定义的层次为2,依次类推 指向同一程序体中定义的上一个名字在nametab中的位置,每个程序体在nametab中登记的第一个名字的link为0 名字标识符 一个布尔量,用于标明名字是否为变量形参名,当名字是否为变量形参名时填入false,其他情况填入true或不填 名字种类,可以是常量(constant)、变量(variable)、类型(type)、过程(procedure) 名字的类型,类型有整型(ints)、字符型(chars)、布尔型(bool)、数组(arrays),对于无类型的名字填入notype 当名字为数组类型或数组变量名时,ref指向该数组在数组信息表中的位置;当名字为过程名时,ref指向该过程在程序体表(btab)中的位置;其他情况ref为0 adr, 当名字为变量名时(包括形参,存入该变量(或形参)在相应活动记录中分类的存贮单元的相对地址;对于过程名,填入他们相应代码的入口地址 val, 当名字为变量名时,填入他们的相应值 size, 当名字为类型名时,填入该类型数据所需存贮单元的数目

程序体表btab:记录个程序体的总信息,用于对源程序中定义的名字的作用域进行分析;对名字表进行管理 (2) 程序体表btab和层次显示表display 程序体表btab:记录个程序体的总信息,用于对源程序中定义的名字的作用域进行分析;对名字表进行管理 lastpar, 指向本程序体中最后一个形式参在nametab中的位置 last,指向本程序体中最后一个名字在nametab中的位置 psize, 本程序体所有形参所需体积、包括连接数据所占空间 vsize, 本程序体所有局部数据所需空间大小 本程序体所有局部数据所需空间大小 指向本程序体中最后一个名字在nametab中的位置 本程序体所有形参所需体积、包括连接数据所占空间 指向本程序体中最后一个形式参在nametab中的位置

层次显示表display:描述正在处理的各嵌套层,对程序体表进行管理 btab

(3)数组信息表atab 数组下限 数组上限 数组元素的体积 数组本身的体积 inxtyp, 数组的下标类型 eltyp, 数组元素类型 elref, 当元素为数组时,它指向该元素数组信息在atab表中的位置,其他情况为0 low, high, 分别表示数组上下限 elsize, size,分别表示数组元素的体积和数组本身的体积 数组下限 数组上限 数组元素的体积 数组本身的体积 当元素为数组时,它指向该元素数组信息在atab表中的位置,其他情况为0 数组元素类型 数组的下标类型

type a=array[1..10, 1..10] of integer; nametab atab

(4) 中间代码表code code:用于存放编译程序所产生的每条中间代码。

8.3 名字的作用范围 在许多程序语言中,名字都有一个确定的作用范围. 两种程序体结构: 并列结构,如FORTRAN 8.3 名字的作用范围 在许多程序语言中,名字都有一个确定的作用范围. 两种程序体结构: 并列结构,如FORTRAN 嵌套结构,如PASCAL,ADA

PROGRAM MAIN … integer X,Y COMMON /C/A,B END SUBROUTINE SUB1 real X,Z COMMON /C/A1,B1

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.

1. FORTRAN的符号表组织 一个FORTRAN程序由一个主程序段和若干个辅程序段组成. 把局部名和全局名分别存在不同的地方. 2. 嵌套结构语言的符号表组织 如PASCAL、ALGOL、ADA作用域遵循"最近嵌套原则".

PASCAL PASCAL程序本身可以看成是一个操作系统所调用的过程,过程可以嵌套和递归。 一个PASCAL过程: 过程头; 说明段(由一系列的说明语句组成); begin 执行体(由一系列的执行语句组成); end

作用域:一个名字能被使用的区域范围称作这个名字的作用域。 允许同一个标识符在不同的过程中代表不同的名字。 名字作用域规则--"最近嵌套原则" 一个在子程序B1中说明的名字X只在B1中有效(局部于B1); 如果B2是B1的一个内层子程序且B2中对 标识符X没有新的说明,则原来的名字X在 B2中仍然有效。如果B2对X重新作了说明, 那么,B2对X的任何引用都是指重新说明 过的这个X。

A(real) B(real) B(bool) A(integr) program main var A, B : real; … procedure P1 var B:boolean; begin end procedure P2 var A:integer;

两种做法: 引入"过程编号"属性。查找时,先查找本过程编号的名字,查不到则查找外层过程编号的名字,…,等等. 按"栈"式思想组织符号表。查找时,从后往前查找,碰到的第一个名字就是所需查找的名字.

PL语言的中间代码 指令格式: opcod l a 编译是如何确定变量的层数(地址)? 运行是如何根据指令中变量的层数和相对地址确定变量的存储单元?

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.

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.

b1 := a + b 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. function position(id:alfa):integer; var i,j:integer; begin nametab[0].name:=id; j:=level; repeat i:=btab[ display[j] ].last; while nametab[i].name<>id do i:=nametab[i].link; j:=j-1 until (j<0) or (i<>0); if (i=0) then error(10); position:=i end; { position } b1 := a + b

PL语言的中间代码 指令格式: opcod l a 编译是如何确定变量的层数(地址)? 运行时如何根据指令中变量的层数和相对地址确定变量的存储单元?