4
#include <array>                                                                
#include <vector>                                                               
#include <cinttypes>                                                            
#include <iostream>                                                             

using namespace std;                                                            

template<size_t N>                                                              
struct item_t {                                                                 
  array<uint32_t, N> weight = {0};                                              
};                                                                              

int main(void) {                                                                

  vector<item_t<3>> items;                                                      
  items.emplace_back({{9,2,3}});                                                
  cout << items[0].weight[0] << endl;                                           
  return 0;                                                                     
};  

我在这里有点茫然。错误出现在 emplace_back 行上,不知道如何解决。任何帮助或提示将不胜感激,谢谢。

编辑

gcc 版本 4.8.2

$ g++ -std=c++11 test.cpp 
test.cpp: In function ‘int main()’:
test.cpp:16:30: error: no matching function for call to ‘std::vector<item_t<3ul> >::emplace_back(<brace-enclosed initializer list>)’
  items.emplace_back({{9,2,3}});
                              ^
test.cpp:16:30: note: candidate is:
In file included from /usr/include/c++/4.8/vector:69:0,
                 from test.cpp:2:
/usr/include/c++/4.8/bits/vector.tcc:91:7: note: void std::vector<_Tp, _Alloc>::emplace_back(_Args&& ...) [with _Args = {}; _Tp = item_t<3ul>; _Alloc = std::allocator<item_t<3ul> >]
       vector<_Tp, _Alloc>::
       ^
/usr/include/c++/4.8/bits/vector.tcc:91:7: note:   candidate expects 0 arguments, 1 provided

问题在于结构初始化= {0}emplace_back.

4

2 回答 2

7

emplace_back()使用模板参数推导来确定传递给函数的元素的类型。大括号括起来的初始值设定项列表不是表达式,也没有类型,因此不能由模板推导。您必须在此处显式调用构造函数:

items.emplace_back(item_t<3>{{1,2,3}});
于 2014-06-30T15:54:24.800 回答
3

这里有两个问题:

尝试初始化这种类型的对象T称为T{...}聚合初始化。在某些情况下,会为其指定默认行为,即使您没有接受initializer_list. 在C++11中,不允许提供非默认构造函数或类内初始化程序。所以,给定这个定义

template<size_t N>                                                              
struct item_t {                                                                 
  array<uint32_t, N> weight   = {0};                                            
};

你不能写item_t<3> t{1,2,3};

然而,这不是你的问题。您的代码失败的原因是 emplace_back 尝试将参数转发给vectors 基础类型的构造函数。在您的情况下,没有匹配项。请注意,在这种情况下,一个花括号初始化列表并不等同于一个initializer_list,您无法通过添加initializer_list构造函数来解决此问题,并且必须以其他方式帮助编译器。

于 2014-06-30T16:00:01.920 回答