std::flat_set<Key,Compare,KeyContainer>:: replace
From cppreference.net
C++
Containers library
|
(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 |
std::flat_set
|
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]
参见
|
提取底层容器
(公开成员函数) |