Std :: map genişletilmiş başlatıcı listesi neye benzer?


94

Varsa, std::mapgenişletilmiş bir başlatıcı listesi nasıl görünür?

GCC 4.4 ile düşünebildiğim her şeyi ... bazı kombinasyonlarını denedim, ancak derlenen hiçbir şey bulamadım.

Yanıtlar:


150

Var ve iyi çalışıyor:

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

Bir haritanın değer türünün olduğunu unutmayın pair <const key_type, mapped_type>, bu nedenle temelde aynı veya dönüştürülebilir türlerden oluşan bir çiftler listesine ihtiyacınız vardır.

Std :: pair ile birleşik başlatma ile kod daha da basit hale gelir

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

4
Harika, bu onu stil olarak çok güzel kılıyor. Bunu GCC ile kullanabilmek için MSVC 2010 desteğini "bırakabilirim" :).
rubenvb

1
Emin olun derleyici destekler Modern C ++ , çünkü map( std::initializer_list<value_type> init, const Compare& comp = Compare(), const Allocator& alloc = Allocator() );bu yana mevcuttur 11 C ++ ve map( std::initializer_list<value_type> init, const Allocator& );beri yalnızca C ++ 14 . Referans: std :: map
KaiserKatze

2

Doublep'nin cevabına , liste başlatmanın iç içe geçmiş haritalar için de çalıştığını eklemek istiyorum . Eğer bir varsa Örneğin, std::mapbirlikte std::mapdeğerlere, o zaman şu şekilde (sadece emin küme parantezi boğmadıkça yapmak) bunu başlatabilir:

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;
}

Çıktı:

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

Coliru Kodu

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.