vector中emplace_back和push_back的区别

emplace_back和push_back的区别。他们都是往容器中插入元素

emplace_back是c++11新增的成员函数,在vector尾部插入一个新的元素

cpp 复制代码
template< class... Args >
void emplace_back( Args&&... args );

emplace_back可以避免创建元素的额外对象(调用该参数的构造函数来创建新元素),提高代码执行效率

push_back,将该对象的副本插入vector的尾部

cpp 复制代码
void push_back(const T& value);
void push_back(T&& value);

其中,第一个重载将 value 的副本作为左值插入 vector,而第二个重载则将 value 的右值插入 vector,可以用于移动语义。

因此,可以得出 emplaceback 和 pushback 的区别如下:

对于构造元素所需的参数数量,emplaceback 比 pushback 更加灵活。emplaceback 支持任意数量的参数,而 pushback 只接受一个对象作为参数。

emplaceback 构造新元素时,直接在 vector 中分配空间并进行对象构造 ,而 pushback 则是先在栈上创建一个临时对象再将该对象的副本插入 vector 中。因此,使用 emplace_back 可以减少创建不必要的临时对象,提高程序的效率。

在实际编程中,应优先考虑使用 emplaceback,仅当 必须将已有对象 插入到 vector 中时,才使用 pushback。

总结一下:1.emplace可以支持任意数量的参数

2.直接vector分配空间进行对象构造,push_back栈上创建一个临时对象,在创建副本插入

3.仅当必须将已有对象插入vector中,才使用push_back

相关推荐
从以前1 小时前
【算法题解】Bindian 山丘信号问题(E. Bindian Signaling)
开发语言·python·算法
不白兰1 小时前
[代码随想录23回溯]回溯的组合问题+分割子串
算法
御风@户外2 小时前
质数生成函数、质数判断备份
算法·acm
闻缺陷则喜何志丹2 小时前
【C++动态规划】1105. 填充书架|2104
c++·算法·动态规划·力扣·高度·最小·书架
Dong雨2 小时前
六大排序算法:插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序
数据结构·算法·排序算法
达帮主2 小时前
7.C语言 宏(Macro) 宏定义,宏函数
linux·c语言·算法
是十一月末2 小时前
机器学习之KNN算法预测数据和数据可视化
人工智能·python·算法·机器学习·信息可视化
chenziang13 小时前
leetcode hot100 路径总和
算法
lyx1426063 小时前
leetcode 3083. 字符串及其反转中是否存在同一子字符串
算法·leetcode·职场和发展
茶猫_3 小时前
力扣面试题 39 - 三步问题 C语言解法
c语言·数据结构·算法·leetcode·职场和发展