Namespaces
Variants

std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>:: insert_or_assign

From cppreference.net
template < class M >
std:: pair < iterator, bool > insert_or_assign ( const key_type & k, M && obj ) ;
(1) (desde C++23)
template < class M >
std:: pair < iterator, bool > insert_or_assign ( key_type && k, M && obj ) ;
(2) (desde C++23)
template < class K, class M >
std:: pair < iterator, bool > insert_or_assign ( K && k, M && obj ) ;
(3) (desde C++23)
template < class M >
iterator insert_or_assign ( const_iterator hint, const key_type & k, M && obj ) ;
(4) (desde C++23)
template < class M >
iterator insert_or_assign ( const_iterator hint, key_type && k, M && obj ) ;
(5) (desde C++23)
template < class K, class M >
iterator insert_or_assign ( const_iterator hint, K && k, M && obj ) ;
(6) (desde C++23)
1,2) Si ya existe una clave equivalente a k en el contenedor, asigna std:: forward < M > ( obj ) al mapped_type correspondiente a la clave k . Si la clave no existe, inserta el nuevo valor como si fuera mediante
El programa está mal formado si cualquiera de std:: is_assignable_v < mapped_type & , M > o std:: is_constructible_v < mapped_type, M > es false .
3,6) Si ya existe una clave equivalente a k en el contenedor, asigna std:: forward < M > ( obj ) al mapped_type correspondiente a la clave k . En caso contrario, equivalente a
La conversión de k a key_type debe construir un objeto u , para el cual find ( k ) == find ( u ) sea true . De lo contrario, el comportamiento es indefinido.
Estas sobrecargas participan en la resolución de sobrecarga solo si:

Contenidos

Parámetros

k - la clave utilizada tanto para buscar como para insertar si no se encuentra
hint - iterador a la posición antes de la cual se insertará el nuevo elemento
obj - el valor a insertar o asignar

Valor de retorno

1-3) El componente bool es true si la inserción tuvo lugar y false si la asignación tuvo lugar. El componente iterador apunta al elemento que fue insertado o actualizado.
4-6) Iterador que apunta al elemento que fue insertado o actualizado.

Complejidad

1-3) Igual que para emplace .
4-6) Igual que para emplace_hint .

Notas

insert_or_assign proporciona más información que operator [ ] y no requiere que el tipo mapeado sea default-constructible.

Ejemplo

#include <flat_map>
#include <iostream>
#include <string>
void print_node(const auto& node)
{
    std::cout << '[' << node.first << "] = " << node.second << '\n';
}
void print_result(auto const& pair)
{
    std::cout << (pair.second ? "inserted: " : "assigned: ");
    print_node(*pair.first);
}
int main()
{
    std::flat_map<std::string, std::string> map;
    print_result(map.insert_or_assign("a", "apple"));
    print_result(map.insert_or_assign("b", "banana"));
    print_result(map.insert_or_assign("c", "cherry"));
    print_result(map.insert_or_assign("c", "clementine"));
    for (const auto& node : map)
        print_node(node);
}

Salida:

inserted: [a] = apple
inserted: [b] = banana
inserted: [c] = cherry
assigned: [c] = clementine
[a] = apple
[b] = banana
[c] = clementine

Véase también

acceder o insertar elemento especificado
(función miembro pública)
acceder elemento especificado con verificación de límites
(función miembro pública)
inserta elementos
(función miembro pública)
construye elemento in-situ
(función miembro pública)
inserta in-situ si la clave no existe, no hace nada si la clave existe
(función miembro pública)