Як би виглядав розширений список ініціалізаторів std :: map?


90

Якщо він взагалі існує, як би std::mapвиглядав розширений список ініціалізатора?

Я пробував деякі комбінації ... ну, все, що міг подумати з GCC 4.4, але не знайшов нічого, що було б скомпільовано.

Відповіді:


145

Він існує і працює добре:

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

Пам’ятайте, що значенням карти є тип pair <const key_type, mapped_type>, тому вам в основному потрібен список пар з однаковими або конвертованими типами.

Завдяки уніфікованій ініціалізації за допомогою std :: pair код стає ще простішим

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

3
Чудово, це робить це дуже приємним стилем. Я міг би просто "відмовитись" від підтримки MSVC 2010, щоб мати можливість використовувати це з GCC :).
rubenvb

1
Переконайтеся, що ваш компілятор підтримує сучасний C ++ , оскільки map( std::initializer_list<value_type> init, const Compare& comp = Compare(), const Allocator& alloc = Allocator() );він доступний з C ++ 11 і map( std::initializer_list<value_type> init, const Allocator& );доступний лише з C ++ 14 . Довідка: std :: map
KaiserKatze

2

До відповіді doublep я хотів би додати , що ініціалізація списку також працює для вкладених карт. Наприклад, якщо у вас є значення std::mapзі std::mapзначеннями, ви можете ініціалізувати його наступним чином (лише переконайтесь, що не втопитеся в фігурних дужках):

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

Вихід:

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

Кодекс про Коліру

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.