template <class... Args>
iterator emplace_hint(const_iterator hint, Args&&... args);
概要
要素が配置されるべき場所を示唆するパラメータ hint
を使って、コンテナに新しい要素を挿入する。要素は直接構築される(コピーもムーブもされない)。要素のコンストラクタはこの関数に渡された引数と同じ引数で呼ばれる。
パラメータ
hint
: 新しい要素をどこへ挿入するかを示唆するために使われるイテレータargs...
: 要素のコンストラクタへ転送される引数パック
戻り値
挿入された要素へのイテレータを返す。
計算量
一般にコンテナのサイズについて対数時間だが、新しい要素が hint
の前に挿入された場合は償却定数時間。
備考
この関数が呼ばれた後も、当該コンテナ内の要素を指す参照やイテレータは無効にはならない。
なお、規格書に明確な記載は無いが、当該コンテナ内の要素を指すポインタも無効にはならない。
例
#include <iostream>
#include <map>
#include <utility>
int main()
{
std::multimap<int, char> m;
m.emplace( 1, 'A' );
// キー2の要素が最後尾に追加されることが事前にわかっているので、m.end()をヒントとして与える
m.emplace_hint( m.end(), 2, 'B' );
for( const auto& pr : m ) {
std::cout << std::get<0>( pr ) << " " << std::get<1>( pr ) << std::endl;
}
return 0;
}
出力
1 A
2 B
バージョン
言語
- C++11
処理系
- Clang: 3.2 ✅
- GCC: 4.8.5 ✅
- ICC: ??
- Visual C++: 2012 ✅
関連項目
名前 | 説明 |
---|---|
multimap::emplace |
要素を直接構築する |
multimap::insert |
要素を挿入する |