C++ push_back和 emplace_back的区别

省流

只有当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 
using namespace std;
#include 
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;
	
}

C++ push_back和 emplace_back的区别_第1张图片

当参数是左值对象时

无区别,都是调用拷贝构造函数

	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;

C++ push_back和 emplace_back的区别_第2张图片

你可能感兴趣的:(c/c++,#,c++11以上新特性,c++)