gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 18:37:00 31 4
gpt4 key购买 nike

我有一个类似于以下的工作语法:

stock_price = symbol_ >> date_ >> price_;
stock_prices_ = stock_price_ >> stock_prices_ | eps;
grammar_ = lit( "PRICES" ) >> stock_prices_ >> lit( "END" );

问题是,当股票价格列表太高时(比如大约 1000 个价格),系统会使用 exc_bad_access 解析段错误。我实际上可以通过以下方式解决这个问题:

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

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

最佳答案

我可能完全忽略了这里的问题,但是 kleene star 有什么问题吗? , plus parser和或list parser directive是吗?

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 语法中处理深度递归的正确方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20686757/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com