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

相关推荐
放羊郎3 小时前
基于ORB-SLAM2算法的优化工作
人工智能·算法·计算机视觉
mask哥3 小时前
力扣算法java实现汇总整理(上)
java·算法·leetcode
如果'\'真能转义说4 小时前
OOXML 文档格式剖析:哈希、ZIP结构与识别
xml·算法·c#·哈希算法
夏日听雨眠4 小时前
数据结构(栈和队列)
数据结构
梦梦代码精5 小时前
BuildingAI 上部署自定义工作流智能体:5 个实用技巧
大数据·人工智能·算法·开源软件
Zephyr_06 小时前
Leedcode算法题
java·算法
流年如夢6 小时前
栈和列队(LeetCode)
数据结构·算法·leetcode·链表·职场和发展
Hello.Reader8 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
绛橘色的日落(。・∀・)ノ8 小时前
机器学习之评估与偏差方差分析
算法