如何在std :: vector中生成对象且不复制?

时间:2019-07-05 04:28:07

标签: c++ performance c++11 stl

有一个学生班

class Student
{
public:
    inline static int current_id_max = 0;
    int id = 0;
    string name;
public:
    Student()
    {
        id = (++current_id_max);
        cout << "Student constructor\n";
    }
    Student(const string& _name)
    {
        name = _name;
        id = (++current_id_max);
        cout << "Student constructor: " << _name << endl;
    }
    Student(const Student& o)
    {
        name = o.name;
        id = (++current_id_max);
        cout << "Student constructor copy: " << name << endl;
    }
    ~Student() { cout << "Student destructor: " << name << endl; }
};

我想在向量中创建5个带有参数的学生,

std::vector<Student> school = 
    { Student("Tom"), Student("Mike"),Student("Zhang"), Student("Wang"), Student("Li")};

将有5个Student constructor: name和5个Student constructor copy: name

我该怎么做才能避免无用的复制?

1 个答案:

答案 0 :(得分:10)

我建议以下内容:

  1. 创建一个空向量。
  2. 保留您想要在向量中包含的元素数量。
  3. 使用std::vector::emplace_back向其中添加元素。

完整的示例:

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

class Student
{
   public:
      inline static int current_id_max = 0;
      int id = 0;
      std::string name;
   public:
      Student()
      {
         id = (++current_id_max);
         std::cout << "Student constructor\n";
      }
      Student(const std::string& _name)
      {
         name = _name;
         id = (++current_id_max);
         std::cout << "Student constructor: " << _name << std::endl;
      }
      Student(const Student& o)
      {
         name = o.name;
         id = (++current_id_max);
         std::cout << "Student constructor copy: " << name << std::endl;
      }
      ~Student() { std::cout << "Student destructor: " << name << std::endl; }
};

int main()
{
   std::vector<Student> school;
   school.reserve(5);
   school.emplace_back("Tom");
   school.emplace_back("Mike");
   school.emplace_back("Zhang");
   school.emplace_back("Wang");
   school.emplace_back("Li");
}

我的测试中的输出:

Student constructor: Tom
Student constructor: Mike
Student constructor: Zhang
Student constructor: Wang
Student constructor: Li
Student destructor: Tom
Student destructor: Mike
Student destructor: Zhang
Student destructor: Wang
Student destructor: Li