📄 8.2.0.htm
字号:
<html>
<head>
<title>编译原理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<link type="text/css" rel="stylesheet" href="../css/specification.css">
</head>
<body>
<table align=right width=300>
<tr>
<td><img src="../images/previous.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='8.1.0_2b.htm'"></td>
<td><img src="../images/next.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='8.2.0b.htm'"></img></td>
</tr>
</table>
<br><br>
<font class="title2"><b>8.2 运行存储管理</b></font>
<p><font class="title2"><b>8.2.0 序言</b></font> </p>
<table><tr><td>    </td>
<td class="content">
<P>语言中过程的语义决定了运行时刻名字如何与存储空间相联系。执行一个过程所需的信息存放在一个称为活动记录的存储块中,过程中的局部名字的存储空间也在活动记录中。
<p>本节,我们讨论运行时刻管理活动记录应生成哪些代码。我们曾经给出两个标准的存储分配策略,即静态分配和栈式分配。对于静态分配,存储器中活动记录的位置在编译时刻便已经确定。至于栈式分配,每次执行一个过程都将有一个新的活动记录置于栈顶,而执行结束时活动记录便被弹出。稍后,我们将考虑一个过程的目标代码如何援引活动记录中的数据对象。
<P>我们知道,一个过程的活动记录包括存放下列信息的域:参数、结果、机器状态信息、局部数据、临时变量等等。本节,我们利用保持着返回地址的机器状态域和局部数据域阐述分配策略,并假定其它域的处理如第六章所述。
<P>由于运行时活动记录的分配和释放是作为过程调用和返回序列的一部分,我们集中讨论如下三地址语句:
<P>1. call (调用);
<p>2. return (返回);
<p>3. halt (暂停);
<p>4. action (动作〕,为其它语句占有位置。
</td></tr></table>
<br>
<table align=right width=300>
<tr>
<td><img src="../images/previous.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='8.1.0_2b.htm'"></td>
<td><img src="../images/next.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='8.2.0b.htm'"></img></td>
</tr>
</table>
</BODY>
</html>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -