为什么不能简单地初始化(带括号)2D std :: array?

Pio*_*ycz 31 c++ stl initialization c++11

可能重复:
c ++为什么std :: vector和std :: array的initializer_list行为不同

我定义了简单的2D数组(3X2):

  std::array<std::array<int,3>,2> a {
    {1,2,3},
    {4,5,6}
  };
Run Code Online (Sandbox Code Playgroud)

我很惊讶这个初始化不起作用,用gcc4.5错误: too many initializers for 'std::array<std::array<int, 3u>, 2u>'

为什么我不能使用这种语法?

我找到了解决方法,一个非常有趣的额外括号,但只是想知道为什么第一个,最简单的方法是无效的?

解决方法:

  // EXTRA BRACES
  std::array<std::array<int,3>,2> a {{
    {1,2,3},
    {4,5,6}
  }};

  // EXPLICIT CASTING
  std::array<std::array<int,3>,2> a {
    std::array<int,3>{1,2,3},
    std::array<int,3>{4,5,6}
  };
Run Code Online (Sandbox Code Playgroud)

[UPDATE]

好的,感谢KerrekSB和评论,我得到了不同.所以在我的例子中似乎有太少的括号,就像在这个C例子中一样:

struct B {
  int array[3];
};
struct A {
  B array[2];
};

B b = {{1,2,3}};
A a = {{
     {{1,2,3}},
     {{4,5,6}}
}};
Run Code Online (Sandbox Code Playgroud)

Ker*_* SB 47

std::array<T, N>包含 C数组的聚合.要初始化它,您需要类本身的外括号和C数组的内括号:

std::array<int, 3> a1 = { { 1, 2, 3 } };
Run Code Online (Sandbox Code Playgroud)

将此逻辑应用于2D数组可以得到:

std::array<std::array<int, 3>, 2> a2 { { { {1, 2, 3} }, { { 4, 5, 6} } } };
//                                   ^ ^ ^ ^            ^ ^
//                                   | | | |            | |
//                                   | +-|-+------------|-+
//                                   +-|-+-|------------+---- C++ class braces
//                                     |   |
//                                     +---+--- member C array braces
Run Code Online (Sandbox Code Playgroud)

  • 但这样可以正常工作:`std :: array <int,3> a1 {1,2,3};`? (3认同)
  • @PiotrNycz:只有你非常草率并忽略所有警告.我的编译器说,`警告:在'std :: array <int,3u> :: value_type [3] {aka int [3]}'[-Wmissing-braces]`的初始化器周围缺少大括号. (3认同)