命名空间
变体
操作

std::inserter

来自 cppreference.com
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
迭代器原语
(C++17 中已弃用)


算法概念和实用程序
间接可调用概念
常见算法要求
(C++20)
(C++20)
(C++20)
实用程序
(C++20)
迭代器适配器
范围访问
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
定义在头文件 <iterator>
template< class Container >

std::insert_iterator<Container>

    inserter( Container& c, typename Container::iterator i );
(直到 C++20)
template< class Container >

constexpr std::insert_iterator<Container>

    inserter( Container& c, ranges::iterator_t<Container> i );
(自 C++20 起)

inserter 是一个便利的函数模板,它为容器 c 及其迭代器 i(类型从参数类型推断)构造一个 std::insert_iterator

内容

[编辑] 参数

c - 支持 insert 操作的容器
i - c 中指示插入位置的迭代器

[编辑] 返回值

一个 std::insert_iterator,它可用于在由 i 指示的位置将元素插入到容器 c 中。

[编辑] 可能实现

template<class Container>
std::insert_iterator<Container> inserter(Container& c, typename Container::iterator i)
{
    return std::insert_iterator<Container>(c, i);
}

[编辑] 示例

#include <algorithm>
#include <iostream>
#include <iterator>
#include <set>
#include <vector>
 
int main()
{
    std::multiset<int> s{1, 2, 3};
 
    // std::inserter is commonly used with multi-sets
    std::fill_n(std::inserter(s, s.end()), 5, 2);
 
    for (int n : s)
        std::cout << n << ' ';
    std::cout << '\n';
 
    std::vector<int> d{100, 200, 300};
    std::vector<int> v{1, 2, 3, 4, 5};
 
    // when inserting in a sequence container, insertion point advances
    // because each std::insert_iterator::operator= updates the target iterator
    std::copy(d.begin(), d.end(), std::inserter(v, std::next(v.begin())));
 
    for (int n : v)
        std::cout << n << ' ';
    std::cout << '\n';
}

输出

1 2 2 2 2 2 2 3 
1 100 200 300 2 3 4 5

[编辑] 缺陷报告

以下更改行为的缺陷报告已追溯应用于以前发布的 C++ 标准。

DR 应用于 发布的行为 正确行为
LWG 561 C++98 i 的类型独立于 Container 它是 Container 的迭代器类型

[编辑] 另请参阅

用于插入容器的迭代器适配器
(类模板) [编辑]
创建一个从参数推断的类型的 std::back_insert_iterator
(函数模板) [编辑]
创建一个从参数推断的类型的 std::front_insert_iterator
(函数模板) [编辑]