- map[meta header]
- std[meta namespace]
- multimap[meta class]
- function template[meta id-type]
- cpp11[meta cpp]
template <class... Args>
iterator
emplace_hint(const_iterator hint,
Args&&... args); // (1) C++11
template <class... Args>
constexpr iterator
emplace_hint(const_iterator hint,
Args&&... args); // (1) C++26要素が配置されるべき場所を示唆するパラメータ 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;
}- emplace_hint[color ff0000]
- m.emplace[link emplace.md]
- m.end()[link end.md]
- std::get[link /reference/utility/pair/get.md]
1 A
2 B
- C++11
- Clang: 3.2 [mark verified]
- GCC: 4.8.5 [mark verified]
- ICC: ??
- Visual C++: 2012 [mark verified]
| 名前 | 説明 |
|---|---|
multimap::emplace |
要素を直接構築する |
multimap::insert |
要素を挿入する |