3

boost 函数make_function_output_iterator将适用于 std::for_each 的函数转换为适用于 std::copy 的迭代器。是否有反向的升压功能。即,采用适合 std::copy 的迭代器并将其转换为适合 std::for_each 的函数。

因此,如果我有一个输出迭代器 output_iter。我需要

for_each(v1.begin(), v1.end(), make_output_iterator_function(output_iter));

做同样的事情

copy(v1.begin(), v1.end(), output_iter);
4

3 回答 3

1

也许std::insert_iterator或者std::transform是你正在寻找的东西?

您可以使用一些魔法来绑定std::insert_iterator::operator=,它会在每次调用时插入:boost::bind

#include <boost/bind.hpp>
#include <vector>
#include <iterator>
#include <algorithm>

    typedef std::vector<int> Container;
    typedef std::insert_iterator< Container > InsertIt;

int main(){
    Container v1, v2;
    InsertIt insert_it (v2,v2.end());
    std::for_each(v1.begin(), v1.end(),
            boost::bind(static_cast<InsertIt& (InsertIt::*)(typename Container::const_reference)>(&InsertIt::operator=), insert_it, _1));
}
于 2012-05-13T17:36:15.767 回答
1

班上

 template<typename T>
 struct iterator_to_function {
      T iter_;
      iterator_to_function(const T& iter) : iter_(iter) {}
      template<typename T2>
      T& operator()(const T2& elem) {*iter_=elem; return ++iter_;}
 };

template<class T>
iterator_to_function<T> make_iterator_function(const T& iter) 
{
  return iterator_to_function<T>(iter);
}

将输出迭代器转换为一元函数。

typedef vector<int> t_vec;
t_vec v;
t_vec v2;
for_each(v.begin(), v.end(), 
         make_iterator_function(back_inserter(v2));
于 2012-05-13T20:37:39.180 回答
1

如果您可以选择,我会使用 lambdas 而不是std/boost::bind,例如:

std::vector<type> v1;
std::for_each(v1.begin(), v1.end() [&output_iter](const type& t) {*output_iter++ = t});

当然,首先使用会更有意义std::copy

于 2012-05-13T20:38:23.960 回答