📄 5.2.1.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='5.2.0.htm'" ></td>
<td><img src="../images/next.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='5.2.2.htm'"></img></td>
</tr>
</table>
<br><br>
<font class="title2"><b>5.2.1 语法树</b></font>
<table>
<tr>
<td>    </td>
<td class="content">
<p>
用来描述句子的结构的语法树与分析树相比,其形式较为简洁。如产生式s→<b>if</b> B <b>then</b> S<sub>1</sub> <b>else</b> S<sub>2</sub>在语法树中可能这样出现:
</p>
</td>
</tr>
</table>
<table><tr><td>    </td>
<td class="content">
<p>
<b>if-then-else</b> <br>
/ | \<br>
B S<sub>1</sub> S<sub>2</sub>
</p>
</td></tr></table>
<table><tr><td>    </td>
<td class="content">
<p>
在语法树中,运算符号和关键字都不在叶结点中出现,而是把它们与分析树中作为这些叶结点的父结点的内部结点联系起来。语法树的另一个简化就是单个产生式的链可以被压缩。图5.2的分析树变成如下语法树:
</p>
</td>
</tr>
</table>
<table><tr><td> </td>
<td class="content">
<p> +<br>
/
\<br>
*
4<br>
/ \<br>
3
5<br>
</p>
</td>
</tr>
</table>
<table><tr><td>    </td>
<td class="content">
<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='5.2.0.htm'"></img></td>
<td><img src="../images/next.gif" onmouseover="javascript:style.cursor='hand'" onclick="vbscript:window.location.href='5.2.2.htm'"></img></td>
</tr>
</table>
</BODY>
<html><script language="JavaScript">
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -