如果我有一个符号表:
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内部调用函数器的方式有关,但我不知道。
我做错了什么?
发布于 2013-02-27 09:26:25
可能是这样的
您可以使_found字段成为一个引用(要求您确保遵守三重规则才能使其工作)。
下面的演示展示了通过SymbolSearcher断言往返结果的原理:
#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());
}https://stackoverflow.com/questions/15099202
复制相似问题