std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>::replace
Von cppreference.com
| void replace( key_container_type&& key_cont, mapped_container_type&& mapped_cont ); |
(seit C++23) | |
Ersetzt die zugrundeliegenden Container c. Entspricht
c.keys = std::move(key_cont); c.values = std::move(mapped_cont);
Die folgenden Bedingungen müssen erfüllt sein
- Der Ausdruck key_cont.size() == mapped_cont.size() ist true,
- Die Elemente von key_cont sind sortiert bezüglich
compare, und - key_cont enthält keine gleichen Elemente.
Andernfalls ist das Verhalten undefiniert.
Inhalt |
[bearbeiten] Parameter
| keys_cont | - | ein sortierter Schlüsselcontainer vom Typ KeyContainer, dessen Inhalt in *this verschoben wird |
| mapped_cont | - | ein Container für zugeordnete Werte vom Typ MappedContainer, dessen Inhalt in *this verschoben wird |
[bearbeiten] Rückgabewert
(keine)
[bearbeiten] Komplexität
Entspricht der Komplexität von std::move angewendet auf die angepassten Container.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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); }
Ausgabe
{1: 2.2, 2: 3.3, 3: 1.1}[bearbeiten] Siehe auch
| extrahiert die zugrunde liegenden Container (public member function) |