栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

c++之vector以及deque的一些思考,以及pop与push的具体实现

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

c++之vector以及deque的一些思考,以及pop与push的具体实现

今天在分析threadsafe_stack代码时发现自己对pop和push的具体实现原理以及注意事项还是有点疏漏,然后撸了一遍相关标准库代码,记录一下。
先说结论:

    pop与erase只是移动指针,不会删除内存,但是会调用该位置的析构函数,所以直接用变量引用这块内存是可以的,且不会出错emplace与push如果都是传入右值,那么实际使用上的区别就是emplace的不会调用析构函数,push进去的会调用析构函数move拷贝完了,原来的对象是会析构的
pop与erase

下图为vector< T>的pop_back的调用关系,其内部只是将M_impl._M_finish指针- -,然后调用该T的析构函数。并未完成该对象在该内存的清理,所以后续可以通过指针与引用对该地址进行操作。erase同理,内部函数调用比较类似。

emplace与push

emplace与push两者如果传入的是右值,则都是调用emplace_back
区别在于两者在placement_new那个点调用的构造函数不同,前者是调用构造函数,后者调用拷贝构造函数,所以push之后是需要调用析构,而emplace不需要

示例代码
#include 
#include 
#include 
#include 
#include 
#include 
class Test
{
    public:
    Test(int a):b(a){std::cout<<"Test "<b = t.b; t.b = 0; std::cout<<"Test&& "< v{1,2,3};
    v.pop_back();  
    // v.erase(v.end()-1);
    std::cout<<"vector "< ts;
    std::stack a;
    a.push(1);  //  Test 1,Test&& 1, ~Test 0
    a.emplace(2);  // Test 2,这里没有后面两个,根据上面的分析可得知啦
    
    Test& value = a.top();  //这里value引用了top(),虽然被pop了,但是其值还在
    a.pop();   // ~Test 2
    std::cout<<"value of pop is "<< value.b<<" and "< 
vector 2and 3
Test 1
Test&& 1
~Test 0
Test 2
~Test 2
value of pop is 2 and 1
~Test 1
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/737834.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号