概述
亲这是一款采用递归下降语法分析器,是一种适合手写语法编译器的方法,且非常简单。递归下降法对语言所用的文法有一些限制,但递归下降是现阶段主流的语法分析方法,因为它可以由开发人员高度控制,在提供错误信息方面也很有优势。
语法就是规则,比如C++标识符,第一个字母不能是数字
再比如 大括号一定要匹配,这就是语法
递归下降语法:
先消除左递归(E存在左递归),再避免回溯(本题不存在),文法改为:S->EE->intcE'|floatcE'|(E)E'E'-> Op EE'|εOp->+|-|*|OK,完成! 既然楼主要求了,那俺自己设计一个吧:S->T|S+T|S-TT->F|T*F|T/FF->intc|floatc|(S)还有我有些困惑,就是楼主为什么认为产生式的预测集的交集不为空能呢?原文法的非终结符的预测集的交集已经都为空了啊,S和E的First集都是{intc,floatc,(},Op的First集是{+,-,*,},请您告诉我哪个交集不为空? 多谢楼主指教,看明白了,确实我原来那个文法预测集的交集不为空(汗,没考虑E'推空的情况),不过我写的第二个文法绝对满足递归下降分析,我编过那个计算器的程序。 消除第二个文法的左递归:S->TS'S'->S''S'|εS''->+T|-TT->FT'T'->T''T'|εT''->*F|/FF->intc|floatc|(S)
最后
以上就是留胡子石头为你收集整理的Java中语法分析器_语法分析器(java语法分析器)的全部内容,希望文章能够帮你解决Java中语法分析器_语法分析器(java语法分析器)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复