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

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 starplus parser和或list parser directive怎么了?

stock_prices_ = +stock_price_ | eps; // one or more stock_price_ or nothing

但是,这似乎恰好是克林星的语义:
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队长,不吃换行符

09-30 14:13
查看更多