У меня есть вектор указателей. Я хотел бы вызвать функцию для каждого элемента, но та функция берет ссылку. Существует ли простой способ разыменовать элементы?
Пример:
MyClass::ReferenceFn( Element & e ) { ... }
MyClass::PointerFn( Element * e ) { ... }
MyClass::Function()
{
std::vector< Element * > elements;
// add some elements...
// This works, as the argument is a pointer type
std::for_each( elements.begin(), elements.end(),
boost::bind( &MyClass::PointerFn, boost::ref(*this), _1 ) );
// This fails (compiler error), as the argument is a reference type
std::for_each( elements.begin(), elements.end(),
boost::bind( &MyClass::ReferenceFn, boost::ref(*this), _1 ) );
}
Я мог создать грязную небольшую обертку, которая берет указатель, но я полагал, что должен был быть лучший путь?
Вы можете использовать boost :: Indirect_iterator
:
std::for_each( boost::make_indirect_iterator(elements.begin()),
boost::make_indirect_iterator(elements.end()),
boost::bind( &MyClass::ReferenceFn, boost::ref(*this), _1 ) );
Это приведет к разыменованию адаптированный итератор дважды в своем операторе *
.
Похоже, вы также можете использовать Boost .Lambda библиотека.
// Appears to compile with boost::lambda::bind
using namespace boost::lambda;
std::for_each( elements.begin(), elements.end(),
bind( &MyClass::ReferenceFn, boost::ref(*this), *_1 ) );
Но я согласен с комментаторами о предпочтении BOOST_FOREACH
. «Алгоритм» for_each
практически не делает ничего полезного, и то, что он делает, цикл for на основе диапазона может сделать для вас с гораздо меньшими усилиями.