Вчера я задал этот вопрос, и «juanchopanza» ответил на мой вопрос, но, к сожалению, я не смог поймать один из ограниченных типов. Поскольку использование «посетителя» более надежное, мне также интересно, кто-нибудь может дать мне решение, используя «посетителя»?using apply_visitor для фильтрации из вектора варианта
Я ищу наилучший способ фильтрации вектора варианта наддува, который был определен, как это:
boost::variant<T1*, T2, T3> Var;
std::vector<Var> Vec;
, когда я называю этот вектор, то, что является лучшим способом для фильтрации только T2 ограниченного типа и вставить в новый вектор? или по-другому, я хочу что-то вроде этого
std::vector<T2> T2Vec =
... (как отфильтровать его от Vec использованием apply_visitor) ...
еще раз спасибо!
EDIT: sulotion от @ НАВСЕГДА:
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));
могли бы вы сказать мне, что здесь не так?
'T_visitor vis (t1vec);' Здесь отсутствуют аргументы шаблона. –
@juanchopanza для этого посетителя. Как я могу изменить его таким образом, чтобы новый вектор содержал адрес объектов в памяти, или вектор указателей указывал на эти объекты? –
Вы можете использовать 'std :: vector', а затем 'vec.push_back (& value)', но будьте осторожны: перераспределение векторов может привести к тому, что указатели или итераторы будут недействительными к элементам вектора. –
juanchopanza