这是由大括号省略的工作方式引起的。从 N3485,8.5.1.11:
可以在初始化列表中省略大括号,如下所示。如果初始化器列表以左大括号开头,则后续的初始化器子句的逗号分隔列表初始化子聚合的成员;初始化子句比成员多是错误的。但是,如果子聚合的初始化器列表不以左大括号开头,则仅从列表中获取足够的初始化器子句来初始化子聚合的成员;任何剩余的初始化子句都被留下来初始化当前子聚合是其成员的聚合的下一个成员。
换句话说,如果接下来是一个初始化列表,我们可以假设没有发生大括号省略。大括号插入在最内层,所以虽然我们想要以下
{{"a", "b"}, {"c", "d"}} -> {{{"a", "b"}, {"c", "d"}}}
我们反而得到
{{"a", "b"}, {"c", "d"}} -> {{{"a", "b"}}, {"c", "d"}}
现在关于为什么我们可以省略更多的大括号并编写{"a", "b", "c", "d"}
:一旦我们点击"a"
,我们知道大括号省略已经发生,因为我们期望数组成员使用初始化列表进行初始化。因此,我们开始使用尽可能多的初始化子句来初始化成员数组。同样,我们点击了"a"
而不是初始化器列表,因此我们开始使用尽可能多的初始化器子句来初始化第一个Foo
。我们第二次重复这个Foo
,消耗所有子句,最后得到
{"a", "b", "c", "d"} -> {{{"a", "b"}, {"c", "d"}}}
如预期的。