Se ela existir, como seria uma std::map
lista de inicializadores estendida?
Eu tentei algumas combinações de ... bem, tudo que pude pensar com o GCC 4.4, mas não encontrei nada compilado.
Respostas:
Existe e funciona bem:
std::map <int, std::string> x
{
std::make_pair (42, "foo"),
std::make_pair (3, "bar")
};
Lembre-se de que o tipo de valor de um mapa é pair <const key_type, mapped_type>
, portanto, você basicamente precisa de uma lista de pares do mesmo tipo ou de tipos conversíveis.
Com a inicialização unificada com std :: pair, o código se torna ainda mais simples
std::map <int, std::string> x {
{ 42, "foo" },
{ 3, "bar" }
};
map( std::initializer_list<value_type> init, const Compare& comp = Compare(), const Allocator& alloc = Allocator() );
está disponível desde C ++ 11 e map( std::initializer_list<value_type> init, const Allocator& );
só está disponível a partir de C ++ 14 . Referência: std :: map
Gostaria de acrescentar à resposta de doublep que a inicialização de lista também funciona para mapas aninhados. Por exemplo, se você tiver um std::map
com std::map
valores, poderá inicializá-lo da seguinte maneira (apenas certifique-se de não se afogar em colchetes):
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;
}
Resultado:
1 => a-> 1 b-> 2
3 => c-> 3 d-> 4 e-> 5