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


93

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

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

Ответы:


149

Он существует и хорошо работает:

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.