std::flat_multimap<Key,T,Compare,KeyContainer,MappedContainer>:: emplace
|
template
<
class
...
Args
>
iterator emplace ( Args && ... args ) ; |
(C++23以降)
(C++26以降 constexpr) |
|
与えられた args を使用して、その場で構築された新しい要素をコンテナに挿入します。
t 型のオブジェクトを std:: pair < key_type, mapped_type > で初期化し、 std:: forward < Args > ( args ) ... を用いて構築する。マップが既に t. first と等価なキーを持つ要素を含む場合、 * this は変更されない。それ以外の場合、以下と等価:
auto key_it = ranges::upper_bound(c.keys, t.first, compare); auto value_it = c.values.begin() + std::distance(c.keys.begin(), key_it); c.keys.insert(key_it, std::move(t.first)); c.values.insert(value_it, std::move(t.second));
このオーバーロードは、以下の条件が満たされる場合にのみオーバーロード解決に参加します: std:: is_constructible_v < std:: pair < key_type, mapped_type > , Args... > が true である場合です。
value_type
が
EmplaceConstructible
ではなく、
flat_multimap
に
args
から構築できない場合、動作は未定義です。
| イテレータの無効化に関する情報は こちら からコピーされています |
目次 |
パラメータ
| args | - | 要素のコンストラクタに転送する引数 |
戻り値
挿入された要素へのイテレータ。
例外
何らかの理由で例外がスローされた場合、この関数は何も効果を持ちません( strong exception safety guarantee )。
計算量
コンテナのサイズに対して線形
注記
emplace
の注意深い使用により、新しい要素は不必要なコピー操作やムーブ操作を回避しながら構築することができます。
例
#include <iostream> #include <string> #include <utility> #include <flat_map> int main() { std::flat_multimap<std::string, std::string> m; // pairのムーブコンストラクタを使用 m.emplace(std::make_pair(std::string("a"), std::string("a"))); // pairの変換ムーブコンストラクタを使用 m.emplace(std::make_pair("b", "abcd")); // pairのテンプレートコンストラクタを使用 m.emplace("d", "ddd"); // 重複キーでのemplace m.emplace("d", "DDD"); // pairのピースワイズコンストラクタを使用 m.emplace(std::piecewise_construct, std::forward_as_tuple("c"), std::forward_as_tuple(10, 'c')); for (const auto& p : m) std::cout << p.first << " => " << p.second << '\n'; }
出力:
a => a b => abcd c => cccccccccc d => ddd d => DDD
関連項目
|
ヒントを使用して要素をその場で構築する
(公開メンバ関数) |
|
|
要素を挿入する
(公開メンバ関数) |