std::flat_set<Key,Compare,KeyContainer>:: extract
|
(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 |
|
container_type extract
(
)
&&
;
|
(C++23부터) | |
적응된 컨테이너
c
를 추출합니다.
return
std
::
move
(
c
)
;
와 동일합니다.
이 작업 후에 * this 는 예외가 발생하더라도 비어 있습니다.
목차 |
반환값
std :: move ( c ) .
복잡도
상수.
예제
#include <cassert> #include <flat_set> #include <print> #include <type_traits> #include <utility> #include <vector> int main() { std::flat_set<int> set{1, 2, 3}; const auto size{set.size()}; auto c{std::move(set).extract()}; assert(c.size() == size); assert(set.empty()); assert(set.keys().empty()); assert(set.values().empty()); // 기본 키 컨테이너는 std::vector입니다: static_assert(std::is_same_v<decltype(c), std::vector<int>>); std::println("{}", c); }
출력:
[1, 2, 3]
참고 항목
|
기본 컨테이너를 교체합니다
(public member function) |