- 1、本文档共32页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
编译原理第六章符号表组织讲述
第 6 章 符号表组织 6.1 符号表的地位和功能 符号表是标识符的动态语义词典,属于编译中语义分析的知识库;主要内容: 6.2 符号表的组织与管理 6.3 符号表的结构设计 【例6.1】有下列函数过程: ※ 符号表的体系结构设计 由于标识符的种类不同,导致语义属性也不尽相同;怎样组织符号表?下面提供一个符号表的体系结构: 6.3.1 符号表总表(SYNBL) 6.3.2 类型表(TAPEL) 6.3.3 数组表(AINFL) 6.3.4 结构表(RINFL) 6.3.5 函数表(PFINFL) 6.3.6 其他表(…) 6.4 符号表的构造过程示例: 练习题: 【习题6.1】解释下述词语: ⑴ 符号表 ; ⑵ 标识符的语义信息; ⑶ 符号表的功能;(4)c语言符号表的管理方式。 ※ 一个函数过程的符号表组织 【习题6.2】设有程序片断如下,试填写符号表: float exe(x,y) int x, y[5][10]; { float a; int b[5][10]; … b[2,5]=15; … } ※ 如何确定下表变量 b[2][5]的地址? 【习题6.3】P236_1,2,3 【习题6.4】P268_1,2 * * 内容提要: ---- 语义分析之一 6.1 符号表的地位和作用 6.2 符号表的组织与管理 6.3 符号表的结构设计 6.4 符号表的构造过程示例 6.5 运行时刻存储分配 ⑴ 名字 — 标识符源码,用作查询关键字; ⑵ 类型 -- 该标识符的数据类型及其相关信息; ⑶ 种类 -- 该标识符在源程序中的语义角色; ⑷ 地址 -- 与值单元相关的一些信息; ① 定义和重定义检查; ② 类型匹配校验; ③ 数据的越界和溢出检查; ④ 值单元存储分配信息; ⑤ 函数、过程的参数传递与校验;… 符号表的功能 标识符四种语义信息 6.2.1 符号表的工作原理 ⑴ 遇 定义性标识符(在说明中)--- 把语义信息填入表中,并修改其TOKEN的指针,使其指向相应的表项: (i , ) 该标识符符号表项 ⑵ 遇 应用性标识符(在语句中)--- 查符号表的相应项,查到后修改其TOKEN的指针,使其指向相应的表项: 6.2.2 符号表的查询、访问方式 线性表、顺序表、索引表和散列表,皆可以采用。 (i , ) 该标识符符号表项 6.2.3 符号表的维护、管理方式 ※一个源文件有若干个函数组成,通常,每个函数对应一个符号表,此外,还是有一个公用符号表; ※符号表如何管理?往往取决于所属语言的程序结构,就 C语言来说,可以在内存设置一定长度的符号表区,并建立适当的索引机制,访问相应的符号表: 公用符号表 FUNCTION 2 符号表 FUNCTION 1 符号表 … 现行函数符号表 全局 符号表区 局部 符号表区 … 索引机制 FUNCTION exp(x:REAL;VAR y:INTEGER):REAL; CONST pai=3.14; TYPE arr=ARRAY[1..5,1..10] OF INTEGER; VAR a:arr; b,a:real; BEGIN … ; a[2,5]:=100; b:=z+6;… END; ⑴ 需要进符号表的标识符: exp(函数,附带信息:类型、参数情况和入口地址…), pai(常量),arr(类型),a(下标变量),b(简单变量),… ⑵ 怎样检查出:a 重定义、z 无定义以及下表变量 a[2,5]的值地址在何处?… SYNBL(符号表) NAME TYPE CAT ADDR … PFINFL(函数表) CONSL(常量表) AINFL(数组表) RINFL(结构表) VALL(活动纪录) LENL(长度表) TYPEL(类型表) TVAL TPOINT· … 名字 类型 种类 地址 token i · ADDR CAT TYP NAME ※ 结构: NEME(名字)— 标识符源码(或内部码) TYP(类型) – 指针,指向类型表相应项; CAT(种类) – 种类编码: f(函数),c(常量),t(类型),d(域名), v,vn,vf(变量,换名形参,赋值形参); ADDR(地址) – 指
您可能关注的文档
- 说课九年上册语文第三单元陈晓丽详解.ppt
- 编译原理复习提纲讲述.ppt
- 说明性文本的英译详解.pptx
- 编译原理-第4章+语法讲述.ppt
- 送电线路工技师详解.doc
- 送风机检修技术标准详解.doc
- 编译原理清华大学第9章符号表讲述.ppt
- 编译原理第4章-自顶向下语法方法讲述.ppt
- 编译原理清华大学第8章语法制导翻译和中间代码生成讲述.ppt
- 诵读欣赏,雁门太守行,别云间详解.ppt
- 10《那一年,面包飘香》教案.docx
- 13 花钟 教学设计-2023-2024学年三年级下册语文统编版.docx
- 2024-2025学年中职学校心理健康教育与霸凌预防的设计.docx
- 2024-2025学年中职生反思与行动的反霸凌教学设计.docx
- 2023-2024学年人教版小学数学一年级上册5.docx
- 4.1.1 线段、射线、直线 教学设计 2024-2025学年北师大版七年级数学上册.docx
- 川教版(2024)三年级上册 2.2在线导航选路线 教案.docx
- Unit 8 Dolls (教学设计)-2024-2025学年译林版(三起)英语四年级上册.docx
- 高一上学期体育与健康人教版 “贪吃蛇”耐久跑 教案.docx
- 第1课时 亿以内数的认识(教学设计)-2024-2025学年四年级上册数学人教版.docx
文档评论(0)