std::flat_set<Key,Compare,KeyContainer>:: replace
|
(C++17)
|
||||
| Sequence | ||||
|
(C++11)
|
||||
|
(C++26)
|
||||
|
(C++26)
|
||||
|
(C++11)
|
||||
| Associative | ||||
| Unordered associative | ||||
|
(C++11)
|
||||
|
(C++11)
|
||||
|
(C++11)
|
||||
|
(C++11)
|
||||
| Adaptors | ||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
|
(C++23)
|
||||
| Views | ||||
|
(C++20)
|
||||
|
(C++23)
|
||||
| Tables | ||||
| Iterator invalidation | ||||
| Member function table | ||||
| Non-member function table |
|
void
replace
(
container_type
&&
cont
)
;
|
(C++23以降) | |
基になるコンテナ
c
を置き換えます。次と等価です:
c
=
std
::
move
(
cont
)
;
.
cont
の要素は
compare
に関してソートされていなければならず、かつ
cont
は等しい要素を含んではなりません。そうでない場合、動作は未定義です。
目次 |
パラメータ
| cont | - |
KeyContainer
型のソート済みコンテナ。その内容が
*
this
に移動されます
|
戻り値
(なし)
計算量
適応されたコンテナに適用された std::move の複雑さと等しい。
例
#include <algorithm> #include <cassert> #include <flat_set> #include <print> #include <vector> int main() { std::vector<int> keys{1, 2, 3}; assert(std::ranges::is_sorted(keys)); std::flat_set<int> set; assert(set.empty()); set.replace(keys); assert(set.size() == 3); assert(keys.empty()); std::println("{}", set); // set.keys() }
出力:
[1, 2, 3]
関連項目
|
基となるコンテナを抽出する
(公開メンバ関数) |