ANTLR:为什么这个元组的语法规则不是LL(1)规则?
创始人
2024-11-08 11:00:15
0

示例代码:

tuple
  : '(' expr (',' expr)* ')'    // 一般的元组规则
  | '(' ')'                    // 空元组规则
  ;

expr
  : ID                        // 变量标识符规则
  | INT                       // 整数值规则
  | FLOAT                     // 浮点数值规则
  ;

上面的元组规则包含一个委托规则(nonterminal),即expr。因此,这个规则不是LL(1)规则,因为它无法为符号表达式(可能是一个标识符、一个整数值或一个浮点数值)准确的进行预测。因此,ANTLR生成识别这个规则的分析器(parser)会失败。

为了解决这个问题,我们可以将委托规则提取为一个子规则,并在元组规则中使用通配符(wildcard)来代替逗号符号,从而生成一个LL(1)规则。

示例代码:

tuple
  : '(' exprs? ')'    // 通配符规则
  ;

exprs
  : expr (',' expr)*    // 独立的表达式规则
  ;

expr
  : ID               // 变量标识符规则
  | INT              // 整数值规则
  | FLOAT            // 浮点数值规则
  ;

这个解决方案使用通配符来允许可选的表达式列表,并将表达式列表提取为一个独立的规则。这样,ANTLR将为每个元组规则产生一个唯一的解析动作,以允许其成为LL(1)规则。

注意:这个解决方案代价是冗余的规则,但是这种权衡是必要的,因为

相关内容

热门资讯

必备透视!wepoker透视有... 必备透视!wepoker透视有吗!竟然有辅助教程(真是有挂)-哔哩哔哩1、点击下载安装,wepoke...
解谜透视!红龙poker辅助工... 解谜透视!红龙poker辅助工具!其实真的是有辅助插件(有挂秘笈)-哔哩哔哩1、下载好红龙poker...
必备透视!pokemmo辅助脚... 必备透视!pokemmo辅助脚本!都是是真的有辅助神器(存在有挂)-哔哩哔哩所有人都在同一条线上,像...
教你透视!pokemmo辅助器... 教你透视!pokemmo辅助器!真是是真的有辅助app(有挂技术)-哔哩哔哩1、完成pokemmo辅...
专业透视!德州透视是真的假的!... 专业透视!德州透视是真的假的!一直存在有辅助工具(有挂秘笈)-哔哩哔哩1、德州透视是真的假的破解器简...
解迷透视!德州局脚本!竟然一直... 解迷透视!德州局脚本!竟然一直都是有辅助方法(有挂教程)-哔哩哔哩1、打开软件启动之后找到中间准星的...
分享透视!聚星ai辅助工具下载... 分享透视!聚星ai辅助工具下载!原来有辅助神器(有挂秘笈)-哔哩哔哩1、超多福利:超高返利,海量正版...
科普透视!werplan外开挂... 科普透视!werplan外开挂!总是真的有辅助技巧(有挂方略)-哔哩哔哩1、下载好werplan外开...
普及透视!智星德州有脚本吗!本... 普及透视!智星德州有脚本吗!本来一直总是有辅助工具(有挂技术)-哔哩哔哩1、智星德州有脚本吗辅助软件...
分享透视!佛手在线是不是有挂!... 分享透视!佛手在线是不是有挂!真是真的是有辅助技巧(新版有挂)-哔哩哔哩佛手在线是不是有挂辅助器是一...