std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>::replace
From cppreference.com
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
| void replace( key_container_type&& key_cont, mapped_container_type&& mapped_cont ); |
(since C++23) | |
Replaces the underlying containers c. Equivalent to:
c.keys = std::move(key_cont); c.values = std::move(mapped_cont);
The following conditions must be met:
- The expression key_cont.size() == mapped_cont.size() is true,
- The elements of key_cont are sorted with respect to
compare, and - key_cont does not contain equal elements.
Otherwise, the behavior is undefined.
Contents |
[edit] Parameters
| keys_cont | - | a sorted keys container of type KeyContainer, the contents of which will be moved into *this
|
| mapped_cont | - | a container of mapped values of type MappedContainer, the contents of which will be moved into *this
|
[edit] Return value
(none)
[edit] Complexity
Equals to complexity of std::move applied to adapted containers.
[edit] Example
Run this code
#include <algorithm> #include <cassert> #include <flat_map> #include <print> #include <vector> int main() { std::vector<int> keys{1, 2, 3}; assert(std::ranges::is_sorted(keys)); std::vector<double> values{2.2, 3.3, 1.1}; assert(keys.size() == values.size(); std::flat_map<int, double> map; assert(map.empty(); map.replace(keys, values); assert(map.size() == 3); assert(map.keys() == 3); assert(map.values() == 3); assert(keys.empty(); assert(values.empty(); std::println("{}", map); }
Output:
{1: 2.2, 2: 3.3, 3: 1.1}[edit] See also
| extracts the underlying containers (public member function) [edit] |