operador unordered_map= en C++ STL

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.

  1. La primera versión toma como referencia un mapa_desordenado como argumento y lo copia en un mapa_desordenado.
  2. La segunda versión realiza una asignación de movimiento, es decir, mueve el contenido de un mapa_desordenado a otro mapa_desordenado.
  3. 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:

  1. La primera versión toma la referencia de unordered_map como argumento.
  2. La segunda versión toma la referencia del valor r de un mapa_desordenado como argumento.
  3. 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

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *