编译原理 语法分析与上下文无关文法

本文探讨了编译原理中的上下文无关文法,重点介绍了如何使用BNF和EBNF进行文法表示,并讨论了解决文法二义性的方法,包括最左推导和最右推导。此外,还展示了如何通过强制正确分析书的构造消除二义性,以实现特定的结合性。
摘要由CSDN通过智能技术生成

分析可以用来确定程序的结构。
在这里插入图片描述
程序使用的语法是上下文无关文法,是乔姆斯基分类法则中的第2类语法。

0 1 2 3
文法名称 非限制型文法 上下文有关文法 上下文无关文法 正则文法
对应机器 图灵机 线性(边界)自动机 下推自动机 有穷自动机
识别对象 自然语言 受限自然语言 程序语言 单词

上下文无关文法使用BNF文法表示。文法规则中有一个“推导”的行为,此行为在右边选一个结构名字替换序列。
在这里插入图片描述
推导中有最左推导和最右推导两种方法。

文法可能有二义性,可以通过两种方式来解决。一种是设立消除二义性规则;另一种是将文法变成一个强制正确分析书的构造的格式。

扩展的BNF即EBNF中有{…}和[…]两个符号。分别表示重复和可选。EBNF可以通过作图的方式展示出来。

上面提到,有两种方法可以去除文法的二义性。下面给出第二种解决二义性的方法的例题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值