El ‘=’ es un operador en C++ STL que copia (o mueve) un mapa_desordenado a otro mapa_desordenado y mapa_desordenado::operador= es la función de operador correspondiente. Hay tres versiones de esta función.
- La primera versión toma como referencia un mapa_desordenado como argumento y lo copia en un mapa_desordenado.
- La segunda versión realiza una asignación de movimiento, es decir, mueve el contenido de un mapa_desordenado a otro mapa_desordenado.
- La tercera versión asigna el contenido de una lista de inicializadores a un mapa_desordenado.
Sintaxis
ump.operator= ( unordered_map& ump ) ump.operator= ( unordered_map&& ump ) ump.operator= ( initializer list )
Parámetros:
- La primera versión toma la referencia de unordered_map como argumento.
- La segunda versión toma la referencia del valor r de un mapa_desordenado como argumento.
- La tercera versión toma una lista de inicializadores como argumento.
Valor devuelto: Todos ellos devuelven el valor de este puntero(*this).
El siguiente programa ilustra unordered_map::operator= en C++.
Ejemplo
// C++ code to illustrate the method // unordered_map::operator=() #include <bits/stdc++.h> using namespace std; // merge function template <class T> T merge(T a, T b) { T t(a); t.insert(b.begin(), b.end()); return t; } int main() { unordered_map<int, int> sample1, sample2, sample3; // List initialization sample1 = { { 1, 2 }, { 3, 4 }, { 5, 6 } }; sample2 = { { 7, 8 }, { 9, 10 }, { 11, 12 } }; // Merge both lists sample3 = merge(sample1, sample2); // copy assignment sample1 = sample3; // Print the unordered_map list for (auto& it : sample1) cout << it.first << " : " << it.second << endl; for (auto& it : sample2) cout << it.first << " : " << it.second << endl; for (auto& it : sample3) cout << it.first << " : " << it.second << endl; return 0; }
Producción:
7 : 8 9 : 10 11 : 12 1 : 2 3 : 4 5 : 6 11 : 12 9 : 10 7 : 8 7 : 8 9 : 10 11 : 12 1 : 2 3 : 4 5 : 6
Publicación traducida automáticamente
Artículo escrito por ankit15697 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA