Biblioteca de mapas de C ++ - función at ()

Descripción

La función C ++ std::map::at()devuelve una referencia al valor mapeado asociado con la clave k .

Declaración

A continuación se muestra la declaración de la función std :: map :: at () desde el encabezado std :: map.

C ++ 11

mapped_type& at (const key_type& k);
const mapped_type& at (const key_type& k) const;

Parámetros

k - Valor clave a cuyo valor mapeado se accede.

Valor devuelto

Si el objeto está calificado como constante, el método devuelve una referencia constante al valor mapeado; de lo contrario, devuelve una referencia no constante.

Excepciones

Si la clave no está presente, el método devuelve la excepción out_of_range .

Complejidad del tiempo

Logarítmico, es decir, log (n).

Ejemplo

El siguiente ejemplo muestra el uso de la función std :: map :: at ().

#include <iostream>
#include <map>

using namespace std;

int main(void) {
   /* Initializer_list constructor */
   map<char, int> m = {
            {'a', 1},
            {'b', 2},
            {'c', 3},
            {'d', 4},
            {'e', 5},
            };

   cout << "Value of key m['a'] = " << m.at('a') << endl;

   try {
      m.at('z');
   } catch(const out_of_range &e) {
      cerr << "Exception at " << e.what() << endl;
   }

   return 0;
}

Compilemos y ejecutemos el programa anterior, esto producirá el siguiente resultado:

Value of key m['a'] = 1
Exception at map::at