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
すごい、これはそれをスタイル的にとても素敵にします。これをGCCで使用できるようにするには、MSVC 2010のサポートを「ドロップ」するだけかもしれません:)。
rubenvb 2010

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::mapwith 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

コリルのコード

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.