Используя for_each и повышение:: свяжите с вектором указателей

У меня есть вектор указателей. Я хотел бы вызвать функцию для каждого элемента, но та функция берет ссылку. Существует ли простой способ разыменовать элементы?

Пример:

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 ) );
}

Я мог создать грязную небольшую обертку, которая берет указатель, но я полагал, что должен был быть лучший путь?

9
задан Alex Deem 10 March 2010 в 00:56
поделиться

2 ответа

Вы можете использовать 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 ) );

Это приведет к разыменованию адаптированный итератор дважды в своем операторе * .

15
ответ дан 4 December 2019 в 11:41
поделиться

Похоже, вы также можете использовать 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 на основе диапазона может сделать для вас с гораздо меньшими усилиями.

3
ответ дан 4 December 2019 в 11:41
поделиться
Другие вопросы по тегам:

Похожие вопросы: