Compartilhar via


map::operator

Insere um elemento em um mapa com um valor de chave especificado.

Type& operator[](
   const Key& _Key
);
Type& operator0-(
    Key&& _Key
);

Parâmetros

Parâmetro

Descrição

_Key

O valor do elemento que deve ser inserido.

Valor de retorno

Uma referência ao valor de dados do elemento inserido.

Comentários

Se o valor do argumento não for encontrado, então é inserido em conjunto com o valor padrão do tipo de dados.

operator[] pode ser usado para inserir os elementos em um mapa m usando m[_Key] = DataValue; onde DataValue é o valor de mapped_type de elemento com um valor de chave de _Key.

A o usar operator[] para inserir os elementos, a referência retornado não indica se uma inserção está alterando um elemento pré-existente ou está criando um novo.As funções de membro localizar e inserção podem ser usadas para determinar se um elemento com uma chave especificada já está atual antes de uma inserção.

Exemplo

// map_op_insert.cpp
// compile with: /EHsc
#include <map>
#include <iostream>
#include <string>

int main( )
{
   using namespace std;
   typedef pair <const int, int> cInt2Int;
   map <int, int> m1;
   map <int, int> :: iterator pIter;
   
   // Insert a data value of 10 with a key of 1
   // into a map using the operator[] member function
   m1[ 1 ] = 10;

   // Compare other ways to insert objects into a map
   m1.insert ( map <int, int> :: value_type ( 2, 20 ) );
   m1.insert ( cInt2Int ( 3, 30 ) );

   cout  << "The keys of the mapped elements are:";
   for ( pIter = m1.begin( ) ; pIter != m1.end( ) ; pIter++ )
      cout << " " << pIter -> first;
   cout << "." << endl;

   cout  << "The values of the mapped elements are:";
   for ( pIter = m1.begin( ) ; pIter != m1.end( ) ; pIter++ )
      cout << " " << pIter -> second;
   cout << "." << endl;

   // If the key already exists, operator[]
   // changes the value of the datum in the element
   m1[ 2 ] = 40;

   // operator[] will also insert the value of the data
   // type's default constructor if the value is unspecified
   m1[5];

   cout  << "The keys of the mapped elements are now:";
   for ( pIter = m1.begin( ) ; pIter != m1.end( ) ; pIter++ )
      cout << " " << pIter -> first;
   cout << "." << endl;

   cout  << "The values of the mapped elements are now:";
   for ( pIter = m1.begin( ) ; pIter != m1.end( ) ; pIter++ )
      cout << " " << pIter -> second;
   cout << "." << endl;

// insert by moving key
    map<string, int> c2;
    string str("abc");
    cout << "c2[move(str)] == " << c2[move(str)] << endl;
    cout << "c2["abc"] == " << c2["abc"] << endl;

    return (0); 
}
  
  
  
  
  

Requisitos

Cabeçalho: <map>

namespace: STD

Consulte também

Referência

map Class

Standard Template Library