省流
只有当push_back或者emplace_back的参数是某个类的构造参数时,两个函数才有区别。
当参数是某个类的构造参数时
push_back会先构造一个临时对象,然后调用转移构造把这个对象复制粘贴到vector里面。最后调用析构函数清理掉临时对象。整个过程调用了3个函数。
emplace_back只会调用 一次构造函数,它在vector的空间里面直接创建对象。
class A
{
public:
A(int arg1,double arg2)
{
cout<<"构造函数"<<endl;
}
A(A&& other)
{
cout<<"转移构造"<<endl;
}
~A()
{
cout<<"析构函数"<<endl;
}
}
int main()
{
vector<A> l;
l.push_back(1,2.0);//将输出构造函数、转移构造、析构函数
l.emplace_back(1,2.0);//将只输出构造函数
}
如上面代码
当参数是右值对象时
没有区别,都是调用转移构造函数
#include <iostream>
using namespace std;
#include <vector>
class A
{
public:
A();
A(int arg1, double arg2);
A(A&& other);
A(const A& other);
~A();
private:
};
A::A()
{
}
A::A(int arg1, double arg2)
{
cout << "构造函数" << endl;
}
A::A(A && other)
{
cout << "转移构造" << endl;
}
A::A(const A & other)
{
cout << "拷贝构造" << endl;
}
A::~A()
{
cout << "析构函数" << endl;
}
int main()
{
vector<A> l,l2;
cout << "push_back:" << endl;
l.push_back(A(1, 2.0));
cout << "push_back结束" << endl;
cout << "emplace_back" << endl;
l2.emplace_back(A(1, 2.0));
cout << "emplace_back结束" << endl;
}
当参数是左值对象时
无区别,都是调用拷贝构造函数
A a(1, 2.0);
cout << "push_back_左值对象" << endl;
l.push_back(a);
cout << "end" << endl;
cout << "emplace_back左值对象" << endl;
l2.push_back(a);
cout << "end" << endl;