📄 7.7.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='7.6.3.htm'" ></td>
<td><img src="../images/next.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='7.7.0b.htm'"></img></td>
</tr>
</table>
<br><br>
<font class="title2"><b>7.7 过程调用</b></font>
<table><tr><td>    </td>
<td class="content">
<p>
过程是一个重要而又常用的程序设计结构。本节,我们将讨论如何生成过程调用和返回的中间代码。我们所指的过程包括函数,一个函数是返回一个值的过程。
<p>
考虑如下的一个简单的过程调用语句的文法:
<p> (1) S→call id (Elist)。
<p> (2) Elist→Elist,E
<p> (3) Elist→ E
<p>
正如第六章所讨论的那样,一个过程调用的翻译包括一个调用序列,即进入和离开每一个过程所采取的动作序列。在具体实现上,即使对同样的语言,调用序列也可以是不同的。下面介绍的是典型的一种。
<p>
当发生一个过程调用时,必须为被调用过程分配它的活动记录所需要的存储空间。必须用某种办法把实在参数的信息传递到被调用过程的可取的指定位置。另外需要建立环境指针以便被调用过程能存取外围过程的数据。还应保留调用过程的运行状态以便调用完毕后恢复原来的运行。同样,返回地址应存人指定的单元中。返回地址是被调用过程执行完毕后的转移地址,它经常是调用过程中紧接调用指令之后的指令地址。调用过程的运行状态和返回地址一般都保留在活动记录中的机器状态域。最后,应生成一条转移指令转移到被调用过程的代码的开始位置。
</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='7.6.3.htm'" ></td>
<td><img src="../images/next.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='7.7.0b.htm'"></img></td>
</tr>
</table>
</BODY>
</html>
<html><script language="JavaScript">
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -