Namespaces
Variants

std:: insert_iterator

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(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 >

class insert_iterator : public std:: iterator < std:: output_iterator_tag ,

void , void , void , void >
(C++17まで)
template < class Container >
class insert_iterator ;
(C++17以降)

std::insert_iterator は、構築時に指定されたコンテナに、提供されたイテレータが指す位置へ要素を挿入する LegacyOutputIterator です。このイテレータ(間接参照されているかどうかに関わらず)への代入が行われるたびに、コンテナの insert() メンバ関数が呼び出されます。 std::insert_iterator のインクリメントは何も行いません(no-op)。

目次

メンバー型

メンバー型 定義
iterator_category std:: output_iterator_tag
value_type void
difference_type

void

(C++20まで)

std::ptrdiff_t

(C++20以降)
pointer void
reference void
container_type Container

メンバ型 iterator_category , value_type , difference_type , pointer および reference は、 std:: iterator < std:: output_iterator_tag , void , void , void , void > からの継承によって取得されることが要求される。

(C++17まで)

メンバー関数

新しい insert_iterator を構築する
(public member function)
関連付けられたコンテナにオブジェクトを挿入する
(public member function)
何も行わない
(public member function)
何も行わない
(public member function)

メンバーオブジェクト

メンバー名 定義
container (protected member object) Container* 型のポインタ
iter (protected member object) Container::iterator (until C++20) ranges::iterator_t<Container> (since C++20) 型のイテレータ

#include <algorithm>
#include <iostream>
#include <iterator>
#include <list>
#include <vector>
int main()
{
    std::vector<int> v{1, 2, 3, 4, 5};
    std::list<int> l{-1, -2, -3};
    std::copy(v.begin(), v.end(), // may be simplified with std::inserter
              std::insert_iterator<std::list<int>>(l, std::next(l.begin()))); 
    for (int n : l)
        std::cout << n << ' ';
    std::cout << '\n';
}

出力:

-1 1 2 3 4 5 -2 -3

関連項目

引数から推論された型の std::insert_iterator を作成する
(関数テンプレート)
コンテナの末尾への挿入用イテレータアダプタ
(クラステンプレート)
コンテナの先頭への挿入用イテレータアダプタ
(クラステンプレート)