【编译原理】手工打造语法分析器
创作时间:
作者:
@小白创作中心
【编译原理】手工打造语法分析器
引用
CSDN
1.
https://blog.csdn.net/shuofxz/article/details/137476161
本文将详细介绍编译原理中语法分析器的构建方法,重点讲解递归下降算法和上下文无关文法,并通过具体的代码示例和AST树的生成过程,详细阐述如何处理左递归问题。
一、递归下降算法
还是这个例子:
int age = 45
我们给出这个语法的规则:
intDeclaration : Int Identifier ('=' additiveExpression)?;
如果翻译为程序的话,伪代码如下:
MatchIntDeclare(){
MatchToken(Int); // 匹配 Int 关键字
MatchIdentifier(); // 匹配标识符
MatchToken(equal); // 匹配等号
MatchExpression(); // 匹配表达式
}
输出的 AST 类似于:
Programm Calculator
IntDeclaration age
AssignmentExp =
IntLiteral 45
上面的过程,称为「递归下降算法」。从顶部开始不断向下生成节点,其中还会有递归调用的部分。
二、上下文无关文法
上面的例子比较简单,还可以用正则表达式文法来表示。但如果是个算数表达式呢?正则文法就很难表示了。
- 2+3*5
- 2*3+5
- 2*3
这时我们可以用递归的规则来表示:
additiveExpression
: multiplicativeExpression
| additiveExpression Plus multiplicativeExpression
;
multiplicativeExpression
: IntLiteral
| multiplicativeExpression Star IntLiteral
;
生成的 AST 为:
如果要计算表达式的值,只需要对根节点求值就可以了。这个就叫做「上下文无关文法」。
但你把上述规则翻译为代码逻辑时,会发现一个问题,无限递归。
我们先用个最简单的示例:
additiveExpression
: IntLiteral
| additiveExpression Plus IntLiteral
;
比如输入:
2+3
- 先判断其是不是
IntLiteral,发现不是 - 然后匹配
additiveExpression Plus IntLiteral,此时还没有消耗任何的 token - 先进入的是
additiveExpression,此时要处理的表达式还是2+3 - 又回到开始,无限循环
这里要注意的一个问题:
并不是觉得 2+3 符合 additiveExpression Plus IntLiteral 就能直接按照 + 拆分为两部分,然后两部分分别去匹配。这里是顺序匹配的,直到匹配到该语法规则的结束符为止。在 additiveExpression Plus IntLiteral 中 additiveExpression 的部分,也是在处理完整的 token 的(2+3)。
三、左递归解决方案
改为右递归
如何处理这个左递归问题呢?我们可以把表达式换个位置:
additiveExpression
: IntLiteral
| IntLiteral Plus additiveExpression
;
先匹配 IntLiteral 这样就能消耗掉一个 token,就不会无限循环了。
比如还是 2+3
2+3不是IntLiteral,跳到下面2+3的第一个字符是2被IntLiteral消耗掉,并结束IntLiteral匹配- 然后
+被Plus消耗掉 - 最后
3进入additiveExpression,匹配为第一条规则IntLiteral
这样就结束了,没有无限循环。
改写成算法是:
热门推荐
赵丽蓉春晚经典瞬间,网友热议:怀念国民奶奶
倪海厦:这个脏器,决定了人的寿命,一定要养护好
湖北郧西:“绿电绿桩”护航低碳出行
张博:AI如何破解模糊信息的挑战
揭秘模糊神经网络:AI如何处理模糊信息?
AI去模糊技术新突破:4K超高清视频也能一键清晰!
揭秘AI模糊思维:让算法更懂你!
心电图运动负荷试验:在跑步机上完成的心脏检查
高血压患者日常这些“雷区”别踩!记住5点,出现症状,及时就医
厨师长教你做草莓蛋糕,你学会了吗?
甜蜜时光教你烘焙草莓蛋糕
青少年社交焦虑:成因、影响与应对之道
如何通过情绪价值成为朋友圈里的“人气王”
企业工会互助互济基金:职场情绪价值的最佳实践
情绪价值爆棚:恋爱幸福秘籍
岳飞:一位“武林高手”的忠诚与智慧
【紧急就医必看】北京快速住院指南:为生命争取每一秒
曼谷必打卡:米其林推荐的六家街头美食
春节探亲必知:这些地方禁忌别踩雷!
春节探亲必知:拜年时间和送贺礼小技巧
周慧敏《注定的结局》:一首唱尽失恋人心声的经典之作
《注定的结局》:一首唱尽爱情无奈的经典之作
从“猪王”到昏君:南朝宋明帝刘彧的权力之路
品读文学大师笔下经典的技艺、细节和生命
海鲜挑选注意事项
如何通过饮食有效补充维生素B?
加息、降息是如何影响投资的——从日本加息带动全球股市暴跌说起
日本央行“鹰派”加息、上调通胀预测 日元应声拉升
日本如期加息!日元站上155,美元、原油走跌,黄金强势
饭后一小时吃天麻粉,真的有效吗?