c.AddString({ {"1",1}, {"2", 2}, {"3", 3} });
您正在传递一个花括号初始化列表,它本身包含嵌套的花括号初始化列表到AddString
. std::initializer_list<std::pair<const char*,int>>
如果内部的braced-init-list可以转换为 ,则参数可以匹配参数std::pair<const char*,int>
。
这个重载解决过程分两个步骤进行;首先尝试匹配std::pair
带有std::initializer_list
参数的构造函数。由于std::pair
没有这样的构造函数,因此发生第二步,其中的其他构造函数std::pair<const char*,int>
被枚举为char const[2]
和int
作为参数。这将匹配以下pair
构造函数,因为char const[2]
它可以隐式转换为char const *
,而构造函数本身不是explicit
。
template< class U1, class U2 >
constexpr pair( U1&& x, U2&& y );
引用 N3337 §13.3.1.7/1 [over.match.list]
当非聚合类类型的对象T
被列表初始化 (8.5.4) 时,重载决议分两个阶段选择构造函数:
— 最初,候选函数是类的初始化列表构造函数 (8.5.4)T
和参数list 由作为单个参数的初始值设定项列表组成。
—如果没有找到可行的初始化列表构造函数,则再次执行重载决议,其中候选函数是类的所有构造函数,T
参数列表由初始化列表的元素组成。
如果初始化列表没有元素并且T
有默认构造函数,则省略第一阶段。在复制列表初始化中,如果explicit
选择了构造函数,则初始化为 ill-formed。