C++ 迭代器库 - back_inserter


描述

它构造一个后插入迭代器,在 x 的末尾插入新元素。

宣言

以下是 std::back_inserter 的声明。

C++11

template <class Container>
  back_insert_iterator<Container> back_inserter (Container& x);

参数

x - 它是迭代器将在其中插入新元素的容器。

返回值

它返回 back_insert_iterator,在容器 x 的末尾插入元素。

例外情况

如果 x 在对其应用一元运算符& 时以某种方式抛出异常,则该函数永远不会抛出异常。

时间复杂度

随机访问迭代器的常量。

例子

以下示例显示了 std::back_inserter 的用法。

#include <iostream>
#include <iterator>
#include <vector>
#include <algorithm>

int main () {
   std::vector<int> foo,bar;
   for (int i = 1; i <= 3; i++) {
      foo.push_back(i); bar.push_back(i*1);
   }

   std::copy (bar.begin(),bar.end(),back_inserter(foo));

   std::cout << "foo contains:";
   for ( std::vector<int>::iterator it = foo.begin(); it!= foo.end(); ++it )
      std::cout << ' ' << *it;
   std::cout << '\n';

   return 0;
}

让我们编译并运行上面的程序,这将产生以下结果 -

foo contains: 1 2 3 1 2 3
迭代器.htm