当前位置:网站首页>vector中函数emplace_back的实现原理
vector中函数emplace_back的实现原理
2022-08-04 11:07:00 【老顽固也可爱】
vector中函数emplace_back的实现原理
在vector中的emplace_back函数, 其效率比push_back高很多!
/*例子中使用的Student类的声明*/
class Student
{
private:
int age;
public:
Student();
explicit Student(int age);
~Student();
int getAge();
};
原理分析
push_back函数
vector<Student> team;
team.push(Student(24));
代码运行过程中, 首先是执行Student()创建了一个临时的Student对象, 然后再通过拷贝构造函数把这个临时对象的成员变量值复制到team中的空间里.
二个原因造成效率慢:
- 创建临时Student对象时,需要申请内存空间,申请内存空间一向是耗时很严重的操作
- 拷贝构造函数的复制操作也是需要CPU时间的
emplace_back函数
vector<Student> team;
team.emplace_back(24);
- 这段代码实现的结果和上面是一样的,都在team里添加了一个24岁的Student对象。
- 但在执行效率上,emplace_back函数很快
其原理就是emplace_back函数是直接在team中已有的空间上,调用了Student类的构造函数,节省了临时对象的内存空间申请以及拷贝构造函数的复制操作。
emplace_back实现原理
void* ptr = malloc(sizeof(Student));
new (ptr)Student(100);
cout << ((Student*)ptr)->getAge() << endl;
第1行:主要是分配一个Student对象所需的内存空间,但在vector里,这步不需要考虑,内部会在实现;
第2行:这才是重点,通过这样的语法,就可以对已在的内存空间,调用相应的Student类构造函数进行初始化;
第3行:输出验证结果.
边栏推荐
- Camunda整体架构和相关概念
- JUC(1)线程和进程、并发和并行、线程的状态、lock锁、生产者和消费者问题
- C#/VB.NET:在 Word 中设置文本对齐方式
- 数据化管理洞悉零售及电子商务运营——零售密码
- Difference between ArrayList and LinkedList
- 中介者模式(Mediator)
- Use pytest hook function to realize automatic test result push enterprise WeChat
- Zikko上市同时搭载HDMI2.1和2.5GbE新款雷电4扩展坞
- 学会使用set和map的基本接口
- MATLAB程序设计与应用 3.2 矩阵变换
猜你喜欢
随机推荐
Business collocations
JUC (1) threads and processes, concurrency and parallelism, thread state, locks, producers and consumers
ThreadLocal详细分析
化繁为简!阿里新产亿级流量系统设计核心原理高级笔记(终极版)
WPF 截图控件之画笔(八)「仿微信」
【虹科案例】基于3D相机组装家具
ECCV 2022 | 清华&腾讯AI Lab提出REALY: 重新思考3D人脸重建的评估方法
利用pytest hook函数实现自动化测试结果推送企业微信
Xilinx VIVADO 中 DDR3(Naive)的使用(3)仿真测试
Learn to use the basic interface of set and map
MATLAB程序设计与应用 3.2 矩阵变换
【LeetCode】232.用栈实现队列
AWS Lambda related concepts and implementation approach
【LeetCode】1403.非递增顺序的最小子序列
临床研究方法学,到现场,到数据真实发生的地方 | 对话数智 x 张维拓
命令模式(Command)
zabbix deployment
Super Learning Method
【黄啊码】MySQL入门—2、使用数据定义语言(DDL)操作数据库
【LeetCode】701.二叉搜索树中的插入操作









