Вчера я задал этот вопрос, и «juanchopanza» ответил на мой вопрос, но, к сожалению, я не могу поймать один из ограниченных типов. Поскольку использование «посетителя» более надежно, мне также интересно, кто-нибудь может дать мне решение с помощью «посетителя»?
Я ищу лучший способ отфильтровать вектор варианта наддува, который был определен следующим образом:
boost::variant<T1*, T2, T3> Var;
std::vector<Var> Vec;
Когда я называю этот вектор, каков наилучший способ отфильтровать только ограниченный тип T2 и вставить в новый вектор? или иначе, я хочу что-то подобное
std::vector<T2> T2Vec =
… (как отфильтровать его от Vec, используя apply_visitor) …
еще раз спасибо!
РЕДАКТИРОВАТЬ:
sulotion от @ ForEveR:
template<typename T>
struct T_visitor : public boost::static_visitor<>
{
T_visitor(std::vector<T>& v) : vec(v) {}
template<typename U>
void operator () (const U&) {}
void operator () (const T& value)
{
vec.push_back(value);
}
private:
std::vector<T>& vec;
};
а также:
std::vector<T1> t1vec;
T_visitor<T1> vis(t1vec);
std::for_each(vec.begin(), vec.end(), boost::apply_visitor(vis));
не могли бы вы сказать мне, что здесь не так?
struct T2_visitor : public boost::static_visitor<>
{
T2_visitor(std::vector<T2>& v) : vec(v) {}
template<typename T>
void operator () (const T&) {}
void operator () (const T2& value)
{
vec.push_back(value);
}
private:
std::vector<T2>& vec;
};
std::vector<T2> T2Vec;
T2_visitor vis(T2Vec);
std::for_each(Vec.begin(), Vec.end(), boost::apply_visitor(vis));
Других решений пока нет …