5
#include <vector>
#include <string>
#include <iostream>

struct PersonA {
  int age; std::string name;    
  PersonA(int _age, const std::string& _name) : age(_age), name(_name) {}
};

struct PersonB {
  int age; std::string name;    
  PersonB(int _age, const std::string&& _name): age(_age), name(_name) {}
};

struct PersonC {
  int age; std::string name;
};

int main()
{
  std::vector<PersonA> personA;  
  personA.emplace_back(10, "nameA");   // fine

  std::vector<PersonB> personB;  
  personB.emplace_back(10, "nameB");   // fine

  std::vector<PersonC> personC;  
  //personC.emplace_back(10, "nameC"); // (the implicit move constructor) not viable
                                       // (the implicit default constructor) not viable

  personC.emplace_back();              // UPDATE: fine.
}

问题> 为什么vector::emplace_back请求显式定义构造函数,否则以下行不起作用?

// why it cannot make use of the default constructor of PersonC?
personC.emplace_back(10, "nameC"); 

此外,vector::emplace_back不支持统一初始化。这是否与上述问题有关?

谢谢

4

1 回答 1

6

std::emplace_back()接受您提供给它的参数并将它们完美转发给value_type它应该创建的对象的构造函数(在您的情况下,PersonC)。

C++11 标准的表 101 指定了 的语义emplace_back()

表达式a.emplace_back(args)

返回类型void

操作语义:附加一个用 .T 构造 std::forward<Args>(args)...的类型的对象。

没有构造函数PersonC接受 anint和 a const char*(或任何可以分别从 anint和 a构造的东西const char*),因此错误。

如果您想知道,编译器可以隐式定义的唯一构造函数是默认构造函数、复制构造函数和移动构造函数。

于 2013-07-02T16:57:43.293 回答