node_type extract( const_iterator position ); | (1) | (since C++17) |
node_type extract( const Key& k ); | (2) | (since C++17) |
template< class K > node_type extract( K&& x ); | (3) | (since C++23) |
position
and returns a node handle that owns it.k
, unlinks the node that contains that element from the container and returns a node handle that owns it. Otherwise, returns an empty node handle.Hash::is_transparent
and KeyEqual::is_transparent
are valid and each denotes a type, and neither iterator
nor const_iterator
is implicitly convertible from K
. This assumes that such Hash
is callable with both K
and Key
type, and that the KeyEqual
is transparent, which, together, allows calling this function without constructing an instance of Key
.In either case, no elements are copied or moved, only the internal pointers of the container nodes are repointed .
Extracting a node invalidates only the iterators to the extracted element, and preserves the relative order of the elements that are not erased. Pointers and references to the extracted element remain valid, but cannot be used while element is owned by a node handle: they become usable if the element is inserted into a container.
position | - | a valid iterator into this container |
k | - | a key to identify the node to be extracted |
x | - | a value of any type that can be transparently compared with a key identifying the node to be extracted |
A node handle that owns the extracted element, or empty node handle in case the element is not found in (2,3).
Hash
and KeyEqual
object.size()
).extract is the only way to change a key of a map element without reallocation:
std::map<int, std::string> m{{1, "mango"}, {2, "papaya"}, {3, "guava"}}; auto nh = m.extract(2); nh.key() = 4; m.insert(std::move(nh)); // m == {{1, "mango"}, {3, "guava"}, {4, "papaya"}}
Feature-test macro | Value | Std | Comment |
---|---|---|---|
__cpp_lib_associative_heterogeneous_erasure | 202110L | (C++23) | Heterogeneous erasure in associative containers and unordered associative containers; overload (3) |
#include <algorithm> #include <iostream> #include <string_view> #include <unordered_map> void print(std::string_view comment, const auto& data) { std::cout << comment; for (auto [k, v] : data) std::cout << ' ' << k << '(' << v << ')'; std::cout << '\n'; } int main() { std::unordered_map<int, char> cont{{1, 'a'}, {2, 'b'}, {3, 'c'}}; print("Start:", cont); // Extract node handle and change key auto nh = cont.extract(1); nh.key() = 4; print("After extract and before insert:", cont); // Insert node handle back cont.insert(std::move(nh)); print("End:", cont); }
Possible output:
Start: 1(a) 2(b) 3(c) After extract and before insert: 2(b) 3(c) End: 2(b) 3(c) 4(a)
(C++17) | splices nodes from another container (public member function) |
(C++11) | inserts elements or nodes (since C++17) (public member function) |
(C++11) | erases elements (public member function) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/container/unordered_map/extract