stl之emplace函数的使用
c++11新标准引入了三个新成员-------emplace_front,emplace和emplace_back,这些操作构造而不是拷贝元素,因此相比push_back等函数能更好地避免内存的拷贝与移动,使容器插入元素的性能得到进一步提升。这些操作分别对应push_front,insert和push_back,能够让我们把元素放置在容器头部,一个指定位置之前或容器尾部用法:c.emplace_b
·
- c++11新标准引入了三个新成员-------emplace_front,emplace和emplace_back,这些操作构造而不是拷贝元素,因此相比push_back等函数能更好地避免内存的拷贝与移动,使容器插入元素的性能得到进一步提升。
- 这些操作分别对应push_front,insert和push_back,能够让我们把元素放置在容器头部,一个指定位置之前或容器尾部
用法:
c.emplace_back(t)在c的尾部创建一个值为t的元素
c.emplace_front(t)在c的头部创建一个值为t的元素
c.emplace(p,t)在迭代器p所指向的元素之前创建一个值为t的元素,返回指定新添加元素的迭代器
empalce的特性:
- 当调用push或insert成员函数时,我们将元素类型的对象传递给它们,这些对象被拷贝到容器中。
- 而当我们调用一个emplace成员函数时,则是将参数传递给元素类型的构造函数。
- emplace成员使用这些参数在容器管理的内存空间中直接构造元素。
代码演示:
#include<iostream>
#include<vector>
using namespace std;
class p
{
public:
p() { num = 100; age = 18; name = "无名氏"; }
p(int n,int a,string name) :num(n),age(a),name(name) {};
int num;
int age;
string name;
};
void test()
{
vector<p> v;
//使用三个参数的p的构造函数
v.emplace_back(520, 19, "大忽悠");
p p1;
//使用拷贝构造函数(浅拷贝)
v.emplace_back(p1);
//使用push_back
v.push_back(p1);//正确
//v.push_back(520, 19, "大忽悠");//错误,没有接收三个参数的push_back版本
//对与push_back的正确做法
v.push_back(p(520, 19, "大忽悠"));//创建一个临时的p对象传递给push_back
}
int main()
{
test();
system("pause");
return 0;
}
- 其中对第一个emplace_back的调用和第二个push_back调用都会创建新的p对象。
- 在调用第一个emplace_back时,会在容器管理的内存空间中直接创建对象。
- 而调用第二个push_back则会创建一个局部临时对象,并不会将其压入容器中。
emplace函数的参数根据元素类型而变化,参数必须与元素类型的构造函数相匹配:
#include<iostream>
#include<vector>
using namespace std;
class p
{
public:
p() { num = 100; age = 18; name = "无名氏"; }
p(int n,int a,string name) :num(n),age(a),name(name) {};
p(int n) :num(n){}
int num;
int age;
string name;
};
void test()
{
vector<p> v;
//使用p的默认构造函数
v.emplace_back();
//使用p的有参构造--含三个参数
v.emplace_back(520, 18, "哈哈哈");
//使用p的有参构造---含一个参数
v.emplace_back(520);
}
int main()
{
test();
system("pause");
return 0;
}
总结:
emplace函数在容器中直接构造元素。传递给emplace函数的参数必须与元素类型的构造函数相匹配
更多推荐
已为社区贡献4条内容
所有评论(0)