std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>:: extract
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_map
|
containers extract
(
)
&&
;
|
(自 C++23 起) | |
提取适配后的容器
c
。等价于
return
std
::
move
(
c
)
;
。
在此操作后, * this 将变为空,即使抛出异常也是如此。
目录 |
返回值
std :: move ( c ) 。
复杂度
常量。
示例
运行此代码
#include <cassert> #include <flat_map> #include <print> #include <type_traits> #include <utility> #include <vector> int main() { std::flat_map<int, double> map{{1, 1.1}, {2, 2.2}, {3, 3.3}}; const auto size{map.size()}; auto c{std::move(map).extract()}; assert(c.keys.size() == size); assert(c.values.size() == size); assert(map.empty()); assert(map.keys().empty()); assert(map.values().empty()); // 默认的键和值容器是 std::vector: static_assert(std::is_same_v<decltype(c.keys), std::vector<int>>); static_assert(std::is_same_v<decltype(c.values), std::vector<double>>); std::println("keys: {}", c.keys); std::println("values: {}", c.values); }
输出:
keys: [1, 2, 3] values: [1.1, 2.2, 3.3]
参见
|
替换底层容器
(公开成员函数) |