- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
自顶向下语法分析方法
2021-9-4
自顶向下语法分析方法
2
语法分析是编译程序的核心部分。
语法分析的作用是识别由词法分析给出的单词符号序列是否是给定文法的正确句子()
常用的语法分析方法有自顶向下分析和自底向上分析
2021-9-4
自顶向下语法分析方法
3
自顶向下分析法也称面向目标的分析方法,也就是从文法的开始符号出发企图推导出与输入的单词串完全相匹配的句子。
确定的自顶向下分析方法:对文法有一定的限制,但实现方法简单、直观,便于手工构造或自动生成语法分析器,目前仍是常用的方法之一。
不确定的自顶向下分析方法:带回溯的分析方法,是一种穷举的试探方法,效率低,代价高,极少使用
2021-9-4
自顶向下语法分析方法
4
主要内容
5.1 确定的自顶向下的分析思想
5.2 LL(1)文法的判别
5.3 某些非LL(1)文法到LL(1)文法的等价变换
5.4 不确定的自顶向下分析思想
5.5 确定的自顶向下分析法
2021-9-4
自顶向下语法分析方法
5
5.1 确定的自顶向下分析思想
确定的自顶向下分析方法,是从文法的开始符号出发,考虑如何根据当前的输入符号(单词符号)唯一地确定选用哪个产生式替换相应非终结符以向下推导,或如何构造一课相应的语法树。
2021-9-4
自顶向下语法分析方法
6
例
文法G1[S]:
S → pA | qB
A → cAd | a
B → dB | b
输入串:
W=pccadd
存在推导过程:
S
pA
pcAd
pccAdd
pccadd
W是文法合法的句子
2021-9-4
自顶向下语法分析方法
7
相应的语法树:
文法G1[S]:
S → pA | qB
A → cAd | a
B → dB | b
输入串:W=pccadd
2021-9-4
自顶向下语法分析方法
8
对于这样的文法显然在推导过程中完全可以根据当前的输入符号决定选择哪个产生式往下推导,因此分析过程是唯一的。
这个文法有以下特点:
(1)每个产生式的右边都由终结符号开始;
(2)如果两个产生式有相同的左部,那么它们的右部由不同的终结符号开始。
文法G1[S]:
S → pA | qB
A → cAd | a
B → dB | b
输入串:W=pccadd
2021-9-4
自顶向下语法分析方法
9
例
文法G2[S]:
S → Ap | Bq
A → cA | a
B → dB | b
对于输入串:
W = ccap
存在推导过程:
S
Ap
cAp
ccAp
ccap
W是文法合法的句子
2021-9-4
自顶向下语法分析方法
10
语法树为:
文法G2[S]:
S → Ap | Bq
A → cA | a
B → dB | b
对于输入串:
W = ccap
2021-9-4
自顶向下语法分析方法
11
这个文法的特点是:
(1)产生式的右部不全是由终结符开始
(2)如果两个产生式有相同的左部,它们的右部由不同的终结符或非终结符开始。
(3)文法中无空产生式
对于相同左部的产生式含有非终结符开始的产生式时,在推导过程中选用哪个产生式不太直观。
文法G2[S]:
S → Ap | Bq
A → cA | a
B → dB | b
对于输入串:
W = ccap
2021-9-4
自顶向下语法分析方法
12
设G=(VN,VT,P,S)是上下文无关文法
FIRST()={a| a, a∈VT, , ∈V*}
若 ε则规定ε∈FIRST()
FIRST()为的开始符号集或首符号集
例:文法G2中
FIRST(Ap)= {a, c}
FIRST(Bq)= {b, d}
定义
文法G2[S]:
S → Ap | Bq
A → cA | a
B → dB | b
对于输入串:
W = ccap
2021-9-4
自顶向下语法分析方法
13
考虑文法G2,关于S的两个产生式的右部虽然都以非终结符开始,但它们右部的符号串可以推导出的首符号集合不相交,因而可以根据当前的输入符号是属于哪个产生式的首符号集合而决定选择相应产生式进行推导。
这样仍能构造确定的自顶向下分析。
2021-9-4
自顶向下语法分析方法
14
例
文法G3[S]:
S → aA | d
A → bAS | ε
对于输入串:
W = abd
存在推导过程:
S
aA
abAS
abS
abd
W是文法合法的句子
2021-9-4
自顶向下语法分析方法
15
语法树为:
文法G3[S]:
S → aA | d
A → bAS | ε
对于输入串:
W = abd
2021-9-4
自顶向下语法分析方法
16
可以看出,当某一非
原创力文档


文档评论(0)