我是C ++和Antlr的新手,所以请原谅我的无知。
我需要根据几条规则派生数百万个值。
if len(current_string) > len(longest_string):
longest_string = current_string
print(longest_string)
所以,我只需要解析规则一次并生成仿函数(或lambdas),这样我就可以将它们保存在地图中并随时调用它们。 Ony ob实例每次都不同。
这是我想出的简单示例,k是一个双值,我作为此示例的参数传递,稍后它将是一个对象。
Eg rule1:- Value = ob.field1 * ob.field2 //the user defines the rule
Eg rule2:- Value = 4* ob.field4 < 3* ob.field1 ? 5 : 0b.field6
它会产生以下错误。我想我错误地引用了它们。
grammar calculator;
start: expr EOF;
expr returns [std::function<double(double)> exprEval]
: left=expr op=('+'|'-') right=expr {$exprEval= [](double k)->double { return $left.exprEval(k) + $right.exprEval(k); }; }
| left=expr op=('*'|'/') right=expr {$exprEval= [](double k)->double { std::cout<<2*k<<std::endl; return -2*k; }; }
| '(' expr ')' {$exprEval= [](double k)->double { std::cout<<k<<std::endl; return -1*k; }; }
| numb {$exprEval= [](double k)->double { std::cout<<-1*k<<std::endl; return k; }; }
;
numb
:DOUBLE
|INT
;
INT
: [0-9]+
;
DOUBLE
: [0-9]+'.'[0-9]+
;
WS
: [ \r\n\t] + -> channel (HIDDEN)
;
继续工作之后。
error(67): calculator.g4:6:152: missing attribute access on rule reference left in $left
error(67): calculator.g4:6:172: missing attribute access on rule reference right in $right
如何访问&#34;左&#34;和&#34;对&#34;表达语境来自lambda内部? 或者这不是最好的方法吗?还有更好的方法吗?
我认为每次解析规则都不是一个好主意,因为有数百万条记录。
答案 0 :(得分:1)
你可能可以通过调整你的lambda中的捕获来逃避,但我强烈建议改变你的方法。不要在语法中编写所有代码,而是创建一个监听器(如果需要评估表达式,则创建一个访问者)并实现所有这些。更容易维护,你可以避免这样的麻烦。