std::unordered_map<Key,T,Hash,KeyEqual,Allocator>:: insert_or_assign
| 
           
           
            
             template
            
            
             <
            
            
             class
            
            M
            
             >
            
             
         std:: pair < iterator, bool > insert_or_assign ( const Key & k, M && obj ) ;  | 
         (1) | (depuis C++17) | 
| 
           
           
            
             template
            
            
             <
            
            
             class
            
            M
            
             >
            
             
         std:: pair < iterator, bool > insert_or_assign ( Key && k, M && obj ) ;  | 
         (2) | (depuis C++17) | 
| 
           
           
           
           
            
             template
            
            
             <
            
            
             class
            
            K,
            
             class
            
            M
            
             >
            
             
         std:: pair < iterator, bool > insert_or_assign ( K && k, M && obj ) ;  | 
         (3) | (depuis C++26) | 
| 
           
           
            
             template
            
            
             <
            
            
             class
            
            M
            
             >
            
             
         iterator insert_or_assign ( const_iterator hint, const Key & k, M && obj ) ;  | 
         (4) | (depuis C++17) | 
| 
           
           
            
             template
            
            
             <
            
            
             class
            
            M
            
             >
            
             
         iterator insert_or_assign ( const_iterator hint, Key && k, M && obj ) ;  | 
         (5) | (depuis C++17) | 
| 
           
           
           
           
            
             template
            
            
             <
            
            
             class
            
            K,
            
             class
            
            M
            
             >
            
             
         iterator insert_or_assign ( const_iterator hint, K && k, M && obj ) ;  | 
         (6) | (depuis C++26) | 
         mapped_type
        
       
       correspondant à la clé
       
        
         k
        
       
       . Si la clé n'existe pas, insère la nouvelle valeur comme par
       
        
         insert
        
       
       , en la construisant à partir de
       
        
         value_type
         
          (
         
         k,
         
          
           std::
           
            forward
           
          
         
         
          <
         
         M
         
          >
         
         
          (
         
         obj
         
          )
         
         
          )
         
        
       
       .
      
         mapped_type
        
       
       correspondant à la clé
       
        
         k
        
       
       . Si la clé n'existe pas, construit un objet
       
        u
       
       de type
       
        value_type
       
       avec
       
        
         
          
           std::
           
            forward
           
          
         
         
          <
         
         K
         
          >
         
         
          (
         
         k
         
          )
         
         ,
         
          
           std::
           
            forward
           
          
         
         
          <
         
         M
         
          >
         
         
          (
         
         obj
         
          )
         
         
          )
         
        
       
       , puis insère
       
        u
       
       dans
       
        
         
          *
         
         this
        
       
       . Si
       
        
         hash_function
         
          (
         
         
          )
         
         
          (
         
         u.
         
          first
         
         
          )
         
         
          !
         
         
          =
         
         hash_function
         
          (
         
         
          )
         
         
          (
         
         k
         
          )
         
         
          ||
         
         contains
         
          (
         
         u.
         
          first
         
         
          )
         
        
       
       est
       
        
         
          true
         
        
       
       , le comportement est indéfini. Le
       
        value_type
       
       doit être
       
        
         EmplaceConstructible
        
       
       dans
       
        unordered_map
       
       à partir de
       
        
         
          
           std::
           
            forward
           
          
         
         
          <
         
         K
         
          >
         
         
          (
         
         k
         
          )
         
         ,
         
          
           std::
           
            forward
           
          
         
         
          <
         
         M
         
          >
         
         
          (
         
         obj
         
          )
         
        
       
       . Cette surcharge participe à la résolution de surcharge seulement si
       
        Hash
       
       et
       
        KeyEqual
       
       sont tous deux
       
        transparents
       
       . Cela suppose qu'un tel
       
        Hash
       
       peut être appelé avec les types
       
        K
       
       et
       
        Key
       
       , et que le
       
        KeyEqual
       
       est transparent, ce qui permet ensemble d'appeler cette fonction sans construire d'instance de
       
        Key
       
       .
      Le comportement est indéfini (jusqu'à C++20) Le programme est mal formé (depuis C++20) si std:: is_assignable_v < mapped_type & , M && > est false .
       Si après l'opération le nouveau nombre d'éléments est supérieur à l'ancien
       
        
         
          max_load_factor()
         
        
        
         *
        
        
        
        
         
          bucket_count()
         
        
       
       un rehashing a lieu.
       
       Si un rehashing se produit (en raison de l'insertion), tous les itérateurs sont invalidés. Sinon (aucun rehashing), les itérateurs ne sont pas invalidés.
      
         Table des matières | 
       
Paramètres
| k | - | la clé utilisée à la fois pour la recherche et pour l'insertion si non trouvée | 
| hint | - | itérateur vers la position avant laquelle le nouvel élément sera inséré | 
| obj | - | la valeur à insérer ou assigner | 
Valeur de retour
Complexité
         emplace
        
       
       .
      
         emplace_hint
        
       
       .
      Notes
       
        insert_or_assign
       
       fournit plus d'informations que
       
        
         operator
        
       
       
        
         [
        
        
         ]
        
       
       et ne nécessite pas la constructibilité par défaut du type mappé.
      
| Macro de test de fonctionnalité | Valeur | Std | Fonctionnalité | 
|---|---|---|---|
         
          
           __cpp_lib_unordered_map_try_emplace
          
         
         | 
        
         
          
           201411L
          
         
         | 
        (C++17) | 
         
          
           std::unordered_map::try_emplace
          
         
         ,
         
          std::unordered_map::insert_or_assign
         
         | 
       
         
          
           __cpp_lib_associative_heterogeneous_insertion
          
         
         | 
        
         
          
           202311L
          
         
         | 
        (C++26) | Surcharges hétérogènes pour les fonctions membres restantes dans les conteneurs associatifs ordonnés et non ordonnés . Surcharges ( 3 ) et ( 6 ) . | 
Exemple
#include <iostream> #include <string> #include <unordered_map> 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::unordered_map<std::string, std::string> myMap; print_result(myMap.insert_or_assign("a", "apple")); print_result(myMap.insert_or_assign("b", "banana")); print_result(myMap.insert_or_assign("c", "cherry")); print_result(myMap.insert_or_assign("c", "clementine")); for (const auto& node : myMap) print_node(node); }
Sortie possible :
inserted: [a] = apple inserted: [b] = banana inserted: [c] = cherry assigned: [c] = clementine [c] = clementine [a] = apple [b] = banana
Voir aussi
| 
         accéder ou insérer l'élément spécifié
          (fonction membre publique)  | 
       |
| 
         accéder à l'élément spécifié avec vérification des limites
          (fonction membre publique)  | 
       |
| 
         insère des éléments
         
          
           ou des nœuds
          
          
           
            (depuis C++17)
           
          
         
          (fonction membre publique)  | 
       |
| 
         construit l'élément en place
          (fonction membre publique)  |