欢迎来到天天文库
浏览记录
ID:12578678
大小:443.00 KB
页数:22页
时间:2018-07-17
《编译原理部分课后答案,仅供参考》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、第一章编译程序概述1.1什么是编译程序 编译程序是现代计算机系统的基本组成部分之一,而且多数计算机系统都含有不止一个高级语言的编译程序。对有些高级语言甚至配置了几个不同性能的编译程序。1.2编译过程概述和编译程序的结构 编译程序完成从源程序到目标程序的翻译工作,是一个复杂的整体的过程。从概念上来讲,一个编译程序的整个工作过程是划分成阶段进行的,每个阶段将源程序的一种表示形式转换成另一种表示形式,各个阶段进行的操作在逻辑上是紧密连接在一起的。一般一个编译过程划分成词法分析、语法分析、语义分析、中间代码生成,代码优化和目标代码生成六个阶
2、段,这是一种典型的划分方法。事实上,某些阶段可能组合在一起,这些阶段间的源程序的中间表示形式就没必要构造出来了。我们将分别介绍各阶段的任务。另外两个重要的工作:表格管理和出错处理与上述六个阶段都有联系。编译过程中源程序的各种信息被保留在种种不同的表格里,编译各阶段的工作都涉及到构造、查找或更新有关的表格,因此需要有表格管理的工作;如果编译过程中发现源程序有错误,编译程序应报告错误的性质和错误发生的地点,并且将错误所造成的影响限制在尽可能小的范围内,使得源程序的其余部分能继续被编译下去,有些编译程序还能自动校正错误,这些工作称之为出错处理
3、。图1.3表示了编译的各个阶段。图1.3编译的各个阶段1.3高级语言解释系统 为了实现在一个计算机上运行高级语言的程序,主要有两个途径:第一个途径是把该程序翻译为这个计算机的指令代码序列,这就是我们已经描述的编译过程。第二个途径是编写一个程序,它解释所遇到的高级语言程序中的语句并且完成这些语句的动作,这样的程序就叫解释程序。从功能上说,一个解释程序能让计算机执行高级语言。它与编译程序的主要不同是它不生成目标代码,它每遇到一个语句,就要对这个语句进行分析以决定语句的含义,执行相应的动作。右面的图示意了它的工作机理第二章:PL/0编译程序
4、问答第1题 PL/0语言允许过程嵌套定义和递归调用,试问它的编译程序如何解决运行时的存储管理。答: PL/0语言允许过程嵌套定义和递归调用,它的编译程序在运行时采用了栈式动态存储管理。(数组CODE存放的只读目标程序,它在运行时不改变。)运行时的数据区S是由解释程序定义的一维整型数组,解释执行时对数据空间S的管理遵循后进先出规则,当每个过程(包括主程序)被调用时,才分配数据空间,退出过程时,则所分配的数据空间被释放。应用动态链和静态链的方式分别解决递归调用和非局部变量的引用问题。问答第2题若PL/0编译程序运行时的存储分配策略采用栈
5、式动态分配,并用动态链和静态链的方式分别解决递归调用和非局部变量的引用问题,试写出下列程序执行到赋值语句b∶=10时运行栈的布局示意图。 varx,y; procedurep;vara;procedureq; varb;begin(q) b∶=10;end(q);procedures; varc,d; procedurer;vare,f; begin(r) callq;end(r);begin(s)callr;end(s); begin(p) calls;end(p);begin(main) callp;
6、end(main).答 : 程序执行到赋值语句b∶=10时运行栈的布局示意图为:22问答第3题 写出题2中当程序编译到r的过程体时的名字表table的内容。namekindlevel/valadrsize 答 题2中当程序编译到r的过程体时的名字表table的内容为:namekindlevel/valadrsizexvariable0dx yvariable0dx+1 pprocedure0过程p的入口(待填)5avariable1dx qprocedure1过程q的入口4sprocedure1过程s的入口(待填)5cvar
7、iable2dx dvariable2dx+1 rprocedure2过程r的入口5evariable3dx fvariable3dx+1 注意:q和s是并列的过程,所以q定义的变量b被覆盖。问答第4题 指出栈顶指针T,最新活动记录基地址指针B,动态链指针DL,静态链指针SL与返回地址RA的用途。答 : 栈顶指针T,最新活动记录基地址指针B,动态链指针DL,静态链指针SL与返回地址RA的用途说明如下: T:栈顶寄存器T指出了当前栈中最新分配的单元(T也是数组S的下标)。 B:基址寄存器,指向每个过程被调用时,在数据区S中给它分配的
8、数据段起始地址,也称基地址。 SL:静态链,指向定义该过程的直接外过程(或主程序)运行时最新数据段的基地址,用以引用非局部(包围它的过程)变量时,寻找该变量的地址。 DL:动态链,指向调用该过程前正在运
此文档下载收益归作者所有