Che aspetto avrebbe un elenco di inizializzatori esteso std :: map?


90

Se esiste, come sarebbe un std::mapelenco di inizializzatori esteso?

Ho provato alcune combinazioni di ... beh, tutto quello che potevo pensare con GCC 4.4, ma non ho trovato nulla che fosse compilato.

Risposte:


145

Esiste e funziona bene:

std::map <int, std::string>  x
  {
    std::make_pair (42, "foo"),
    std::make_pair (3, "bar")
  };

Ricorda che il tipo di valore di una mappa è pair <const key_type, mapped_type>, quindi fondamentalmente hai bisogno di un elenco di coppie con tipi uguali o convertibili.

Con l'inizializzazione unificata con std :: pair, il codice diventa ancora più semplice

std::map <int, std::string> x { 
  { 42, "foo" }, 
  { 3, "bar" } 
};

3
Fantastico, questo lo rende molto bello nello stile. Potrei semplicemente "eliminare" il supporto per MSVC 2010 per poterlo utilizzare con GCC :).
rubenvb

1
Assicurati che il tuo compilatore supporti Modern C ++ , perché map( std::initializer_list<value_type> init, const Compare& comp = Compare(), const Allocator& alloc = Allocator() );è disponibile da C ++ 11 ed map( std::initializer_list<value_type> init, const Allocator& );è disponibile solo da C ++ 14 . Riferimento: std :: map
KaiserKatze

2

Vorrei aggiungere alla risposta di doublep che l' inizializzazione dell'elenco funziona anche per le mappe nidificate. Ad esempio, se hai un std::mapcon std::mapvalori, puoi inizializzarlo nel modo seguente (assicurati solo di non annegare tra parentesi graffe):

int main() {
    std::map<int, std::map<std::string, double>> myMap{
        {1, {{"a", 1.0}, {"b", 2.0}}}, {3, {{"c", 3.0}, {"d", 4.0}, {"e", 5.0}}}
    };

    // C++17: Range-based for loops with structured binding.
    for (auto const &[k1, v1] : myMap) {
        std::cout << k1 << " =>";
        for (auto const &[k2, v2] : v1)            
            std::cout << " " << k2 << "->" << v2;
        std::cout << std::endl;
    }

    return 0;
}

Produzione:

1 => a-> 1 b-> 2
3 => c-> 3 d-> 4 e-> 5

Codice su Coliru

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.