c – 在boost :: spirit :: qi语法中处理深度递归的正确方法是什么?

c – 在boost :: spirit :: qi语法中处理深度递归的正确方法是什么?,第1张

概述我有一个类似于以下的工作语法: stock_price = symbol_ >> date_ >> price_;stock_prices_ = stock_price_ >> stock_prices_ | eps;grammar_ = lit( "PRICES" ) >> stock_prices_ >> lit( "END" ); 问题是,当股票价格列表_太高(比如大约1000个价格)时 我有一个类似于以下的工作语法:
stock_price = symbol_ >> date_ >> price_;stock_prices_ = stock_price_ >> stock_prices_ | eps;grammar_ = lit( "PRICES" ) >> stock_prices_ >> lit( "END" );

问题是,当股票价格列表_太高(比如大约1000个价格)时,用exc_bad_access解析seg-fault.我实际上可以解决这个问题:

stock_prices_ = stock_price_ >> stock_price_ >> stock_price_ >> stock_price >> stock_prices_ |                stock_price_ >> stock_prices_ |                eps;

但我不认为这是一个优雅的解决方案.有更好的解决方案吗?

解决方法 我可能在这里完全错过了这个问题,但是 kleene star,plus parser和/或 list parser directives有什么问题?
stock_prices_ = +stock_price_ | eps; // one or more stock_price_ or nothing

然而,这看起来恰好是kleene star的语义:

stock_price = symbol_ >> date_ >> price_;grammar_    = "PRICES" >> *stock_price_ >> "END"; // zero or more stock_price_

现在,如果你想让它们以行分隔,例如,使用1:

grammar_    = "PRICES" >> -(stock_price_ % eol) >> "END";

1与例如qi :: blank队长,不吃换行符

总结

以上是内存溢出为你收集整理的c – 在boost :: spirit :: qi语法中处理深度递归的正确方法是什么?全部内容,希望文章能够帮你解决c – 在boost :: spirit :: qi语法中处理深度递归的正确方法是什么?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1239053.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存