【问题标题】:Searching/Iterating boost::spirit::qi::symbols搜索/迭代 boost::spirit::qi::symbols
【发布时间】:2013-02-12 11:58:58
【问题描述】:

如果我有一个符号表:

struct MySymbols : symbols<char, MyEnum::Fruits>
{
    MySymbols ()
        : symbols<char, MyEnum::Fruits>(std::string("MySymbols"))
    {
        add("apple", MyEnum::Apple)
           ("orange", MyEnum::Orange);
    }
};

我想遍历表以便按数据值搜索符号。我不能使用 lambda 表达式,所以我实现了一个简单的类:

template<typename T>
struct SymbolSearcher
{
    SymbolSearcher::SymbolSearcher(T searchFor)
        : _sought(searchFor)
    {
        // do nothing
    }

    void operator() (std::basic_string<char> s, T ct)
    {
        if (_sought == ct)
        {
            _found = s;
        }
    }

    std::string found() const { return _found; }

private:
    T _sought;
    std::string _found;
};

我的使用方法如下:

SymbolSearcher<MyEnum::Fruits> search(ct);
MySymbols symbols;

symbols.for_each(search);
std::string symbolStr = search.found();

如果我在_found = s 上设置断点,我可以确认 _found 正在设置,但是 search.found() 总是返回一个空字符串。我猜这与在 for_each 中调用仿函数的方式有关,但我不知道。

我做错了什么?

【问题讨论】:

  • nitpick:成员变量应该拼写为 _sought 而不是 _saught :)

标签: c++ boost boost-spirit boost-spirit-qi


【解决方案1】:

可能是这样的

  • 字符串的实际值为空字符串(不太可能)

  • 函子按值传递,使有状态函子无用(因为原始状态实际上不会被传递)。

您可以将_found 字段作为参考(要求您确保遵守三规则以使其发挥作用)。

这是一个通过SymbolSearcher 断言往返结果来展示原理的演示:http://liveworkspace.org/code/4qupWC$1

#include <boost/spirit/include/qi.hpp>

namespace qi     = boost::spirit::qi;

template<typename T>
struct SymbolSearcher
{
    SymbolSearcher(T searchFor, std::string& result) : _sought(searchFor), _found(result)
    {
    }

    void operator() (std::basic_string<char> s, T ct)
    {
        if (_sought == ct)
        {
            _found = s;
        }
    }

    std::string found() const { return _found; }

private:
    T _sought;
    std::string& _found;
};

int main()
{
    const std::string str("mies");

    typedef std::string::const_iterator It;
    It begin = str.cbegin();
    It end   = str.cend();

    qi::symbols<char, int> symbols;
    symbols.add("aap", 1)("noot", 2)("mies", 3);

    int out;
    bool ok = qi::parse(begin, end, symbols, out);
    assert(ok);

    std::string found;
    SymbolSearcher<int> sf(out, found);
    symbols.for_each(sf);

    assert(str == sf.found());
}

【讨论】:

猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-04-06
相关资源
最近更新 更多