- 1、本文档共61页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
PL/O编译程序的目标代码结构 PL/O编译程序所产生的目标代码是一个假想栈式计算机的汇编语言,可称为类PCODE指令代码,它不依赖任何实际计算机 此类栈式机没有累加器和通用寄存器,有一个栈式存储器,有四个控制寄存器(指令寄存器 I,指令地址寄存器 P,栈顶寄存器 T和基址寄存器 B),算逻运算都在栈顶进行。(这部分内容涉及到PL/0解释程序) PL/O编译程序的目标代码结构 指令格式 f 功能码 l 层次差(标识符引用层减去定义层) a 根据不同的指令有所区别 八条目标指令: PL/O编译程序的目标代码结构和代码生成 指令 “LIT 0 A” 立即数存入栈顶,即置T 所指存储单元的值为A T 加 1 LOD:将变量放到栈顶。a域为变量在所说明层中的相对位置,l为调用层与说明层的层差值。 STO:将栈顶的内容送入某变量单元中。a和l域的含意同LOD指令。 CAL:调用过程的指令。a为被调用过程的目标程序入口地址,l为层差。 INT:为被调用的过程(或主程序)在运行栈中开辟数据区。a域为开辟的单元个数。 JMP:无条件转移指令,a为转向地址。 JPC:条件转移指令,当栈顶的布尔值为非真时,转向a域的地址,否则顺序执行。 OPR:关系运算和算术运算指令。将栈顶和次栈顶的内容进行运算,结果存放在次栈顶。此外还可以是读写等特殊功能的指令,具体操作由a域值给出。(P23) PL/0编译程序的代码生成 编译程序的目标代码生成 在分析程序体时生成的 当分析程序体中的每个语句时,当语法正确则调用目标代码生成过程以生成与PL/O语句等价功能的目标代码,直到编译正常结束。除了过程说明部分外,变量和常量的说明都不产生目标代码。 由过程GEN完成,GEN有三个参数,分别代表目标代码的功能码,层差和位移量 P417 例如:gen(opr,0,16) 从命令行读入一个输入到栈顶 PL/0编译程序的代码生成 gen(sto,lev-level,adr) 将栈顶内容送到变量单元中, lev:当前处理的过程层次 level:被引用变量或过程所在层次 CX:为目标代码code数组的下标指针(CX为指令的指针,由0开始顺序增加。) PL/0编译程序的代码生成 相关定义 Code: array[0..cxmax] of instruction; p414 fct=(lit, opr, lod, sto, cal, int, jmp, jpc) P413 Instruction= packec record P413 f: fct; l: 0..levmax a: 0..amax; end; CODE为一维数组,数组元素为记录型数据。每一个记录就是一条目标指令。 PL/0编译程序的代码生成 实际上目标代码的顺序是内层过程的排在前边,主程序的目标代码在最后。 下面我们给出一个PL/0源程序和对应的目标程序的清单。 PL/0编译程序的代码生成 对于过程(分程序)的代码生成 在block入口处生成一条(jmp,0,0)指令,作为过程体入口指令,该指令的第3区域的0需分析到过程体入口时才返填。 对分程序体入口的处理(见程序文本P424页block 的过程体) begin (*block*) dx:=3; tx0:=tx; (*保留当前table表指针值,实际为过程名在table表中的位置*) table[tx].adr:=cx;(*保留当前code指针值到过程名的adr域*) gen(jmp,0,0);(上例的前二行!) 其实上述内容最重要的是地址的回填(见下几页PPT) 附录 当源程序经过语法分析,如果未发现错误时,由编译程序调用解释程序,对目标代码开始进行解释执行。 PL/0解释程序 PL/0解释程序 解释程序定义了4个寄存器: ①I 指令寄存器:存放当前正在解释的一条目标指令 ②P 程序地址寄存器:指向下一条要执行的目标程序的 地址(相当目标程序CODE数组的下标) CODE为一维数组,数组元素为记录型数据。每一个记录就是一条目标指令。 每个过程目标程序的入口都有这样一条指令,用以完成 开辟数据段的工作 A域的值指出数据段的大小,即为局部变量个数+3(联 系单元个数为3) 由编译程序的代码生成给出 开辟数据段的结果是改变栈顶寄存器T的值,即T:=T+A 为调用过程的目标指令 L 为层次差,它是寻找静态链的依据。 A 为被调用过程的目标程序入
您可能关注的文档
- 第三章噪声的评价与标准课件.ppt
- 第三章占有的效力与保护.ppt
- 第三章真空技术基础与等离子体课件.ppt
- 第三章振动课件.ppt
- 第三章制冷压缩机与设备的选型计算.ppt
- 第三章中国纪录片.ppt
- 第三章中国纪录片课件.ppt
- 第三章-中世纪的中国数学.ppt
- 第三章中原民俗.ppt
- 第三章资本和剩余价值课件.ppt
- 2024年高考语文复习 小说文本阅读(十三)练就审美技能,赏析描写艺术 学案.pdf
- 2024年核安全工程师法规考题.pdf
- 2024年高考语文一轮复习讲练测(新教材新高考)第04讲小说情节类题目(讲义)(原卷版+解析).pdf
- 2024年高考语文一轮复习:文言文45个高频词.pdf
- 2024年河南省会计从业资格考试全真模拟试题法规.pdf
- 2024年高考政治必修2《经济与社会》知识细节归纳100条.pdf
- 2024年高考语文一轮复习:27种经典开头方式及精彩范例.pdf
- 2024年高考政治选必一《 当代国际政治与经济》复习导引.pdf
- 2024年湖南省郴州市中考原创命题化学模拟试卷.pdf
- 2024年公司新员工个人工作总结(35篇).pdf
最近下载
- 2023年云南大学滇池学院软件工程专业《数据库原理》科目期末试卷B(有答案).docx VIP
- 平凡的世界(阅读任务三 品味小说语言)公开课一等奖创新教学设计-【中职专用】高一语文(高教版2023-2024基础模块上册).docx VIP
- 国家开放大学《社会保障基础》期末考试题库.pdf
- 佳明手持机从入门到精通.pdf
- 计算机应用基础(本) 终结性考试任务一.docx VIP
- 绵阳中学自主招生考试.doc VIP
- 2023年云南大学滇池学院数据科学与大数据技术专业《数据库原理》科目期末试卷A(有答案).docx VIP
- 国开常见眼病诊断与处理3687期末试题及答案(2022年7月).docx
- (正式版)D-L∕T 659-2016 火力发电厂分散控制系统验收测试规程.docx VIP
- 基坑土钉墙及钢管桩支护施工方案.docx VIP
文档评论(0)