我有以下代码:
#include <boost/any.hpp>
#include <boost/spirit/include/qi.hpp>
#include <iostream>
#include <string>
template <typename Iterator>
struct parser : boost::spirit::qi::grammar<Iterator, boost::any, boost::spirit::qi::ascii::space_type>
{
parser() : parser::base_type(start)
{
start %= boost::spirit::qi::int_;
}
boost::spirit::qi::rule<Iterator, boost::any, boost::spirit::qi::ascii::space_type> start;
};
int main()
{
const std::string input_data("1");
boost::any var;
auto itr = input_data.begin();
auto end = input_data.end();
parser<decltype(itr)> g;
bool res = boost::spirit::qi::phrase_parse(itr, end, g, boost::spirit::ascii::space, var);
if (res && itr == end)
{
std::cout << "Parsing succeeded \n";
try
{
std::cout << boost::any_cast<int>(var) << '\n';
}
catch (const boost::bad_any_cast& ex)
{
std::cerr << ex.what() << '\n';
}
}
else
{
std::cout << "Parsing failed \n";
}
}
输出
Parsing succeeded
boost::bad_any_cast: failed conversion using boost::any_cast
我认为在这种情况下,cast应该可以正常工作。我错了吗?我该如何解决?
最佳答案
初始化您的任何!
boost::any var = 0;
Spirit 通过引用绑定(bind)属性值,因此在调用
int&
解析器之前它将转换为qi::int_
。附带说明一下,将
boost::any
与Spirit一起使用似乎是误导的计划。我看不到为什么您会从静态已知类型和例如变体。但我会留给你:)P.S. 哦,您还忘记了括号like here :)。立即查看 Live On Coliru