名前空間
変種

std::inserter

提供: cppreference.com
 
 
イテレータライブラリ
イテレータコンセプト
イテレータプリミティブ
アルゴリズムのコンセプトとユーティリティ
間接呼び出し可能コンセプト
共通アルゴリズム要件
ユーティリティ
イテレータアダプタ
ストリームイテレータ
イテレータのカスタマイゼーションポイント
イテレータ操作
(C++11)
(C++11)
範囲アクセス
(C++11)(C++14)
(C++11)(C++14)
(C++17)(C++20)
(C++14)(C++14)
(C++14)(C++14)
(C++17)
(C++17)
 
<tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody>
ヘッダ <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 内のイテレータ

戻り値

コンテナ ci に示される位置に要素を挿入するために使用できる std::insert_iterator

実装例

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 <vector>
#include <set>

int main()
{

    std::multiset<int> s {1, 2, 3};

    // std::inserter is commonly used with 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> l {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(l, std::next(l.begin())));

    for (int n : l)
        std::cout << n << ' ';
    std::cout << '\n';
}

出力:

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

関連項目

コンテナに挿入するためのイテレータアダプタ
(クラステンプレート) [edit]
引数から推定した型の std::back_insert_iterator を作成します
(関数テンプレート) [edit]
引数から推定した型の std::front_insert_iterator を作成します
(関数テンプレート) [edit]