std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::extract (3) - Linux Manuals
std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::extract: std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::extract
Command to display std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::extract
manual in Linux: $ man 3 std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::extract
NAME
std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::extract - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::extract
Synopsis
node_type extract( const_iterator position ); (1) (since C++17)
node_type extract( const key_type& x ); (2) (since C++17)
1) Unlinks the node that contains the element pointed to by position and returns a node_handle that owns it
2) If the container has an element with key equivalent to x, unlinks the node that contains the first such element from the container and returns a node_handle that owns it. Otherwise, returns an empty node handle.
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.
Parameters
position - a valid iterator into this container
x - a key to identify the node to be extracted
Return value
A node_handle that owns the extracted element, or empty node handle in case the element is not found in overload (2)
Complexity
1,2) Average case O(1), worst case O(a.size()).
Notes
extract is the only way to change a key of a map element without reallocation:
map<int, string> m{{1, "mango"}, {2, "papaya"}, {3, "guava"}};
auto nh = m.extract(2);
nh.key() = 4;
m.insert(move(nh));
// m == {{1, "mango"}, {3, "guava"}, {4, "papaya"}}
Example
This section is incomplete
Reason: no example
See also
merge splices nodes from another container
(public member function)
(C++17)
inserts elements
or nodes
insert (since C++17)
(public member function)
erases elements
erase (public member function)
Pages related to std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::extract
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::emplace (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::emplace
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::emplace_hint (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::emplace_hint
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::empty (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::empty
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::end(size_type), (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::end(size_type),
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::end(size_type),std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::cend(size_type) (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::end(size_type),std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::cend(size_type)
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::end, (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::end,
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::end,std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::cend (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::end,std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::cend
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::equal_range (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::equal_range
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::erase (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::erase
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::begin(size_type), (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::begin(size_type),
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::begin(size_type),std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::cbegin(size_type) (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::begin(size_type),std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::cbegin(size_type)
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::begin, (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::begin,
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::begin,std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::cbegin (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::begin,std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::cbegin
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::bucket (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::bucket
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::bucket_count (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::bucket_count
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::bucket_size (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::bucket_size
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::clear (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::clear
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::contains (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::contains
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::count (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::count
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::find (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::find
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::get_allocator (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::get_allocator
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::hash_function (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::hash_function
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::insert (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::insert
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::key_eq (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::key_eq
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::load_factor (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::load_factor
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::max_bucket_count (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::max_bucket_count
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::max_load_factor (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::max_load_factor
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::max_size (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::max_size
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::merge (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::merge
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::operator= (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::operator=
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::rehash (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::rehash
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::reserve (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::reserve
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::size (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::size
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::swap (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::swap
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::unordered_multimap (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::unordered_multimap
- std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::~unordered_multimap (3) - std::unordered_multimap<Key,T,Hash,KeyEqual,Allocator>::~unordered_multimap
- std::unordered_multimap (3) - std::unordered_multimap