• CC++中深浅拷贝(map、vector)与内存释放


    1、STL中的容器直接赋值是安全的,即是深拷贝。

    vecotr vec1; vec1.push_back(“helloWorld”); vecotr vec2;

    vec1 = vec2,赋值之后,vec1和vec2之间就没有关联了 。

    关于容器的拷贝见:标准容器的赋值和拷贝是安全的 - 相印 - 博客园 (cnblogs.com)

    ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? C++深拷贝与浅拷贝 - ay-a - 博客园 (cnblogs.com)

    注:深拷贝复制的是地址和内存,浅拷贝复制的是地址。

    2、容器的另一种深拷贝方式是用copy函数,直接上代码:

    #include 
    #include 
    #include 
    #include 
    #include 
    using namespace std;
    
    int main(){
    
    	mapm_map;
    	m_map.insert(make_pair("Element1",5));
    	m_map.insert(make_pair("Element2",15));
    	map::iterator it = m_map.begin(); 
    	for(it;it != m_map.end();it++){
    		cout << "m_map first is " << it->first << ", "<< "m_map second is " << it->second << endl;
    	}
    	cout << "Previous m_map Size is ==========================" << m_map.size() << endl;
    	cout << "Start Copying Map ==============================" << endl;
    	mapm_Copymap;
    /利用copy拷贝//
    	copy(m_map.begin(),m_map.end(),inserter(m_Copymap,m_Copymap.begin()));
    拷贝结束//
    	cout << "Copy Map Done! ======================" << endl;
    	m_map.clear();
    	cout << "Clear Previous Map Done!=======================" << endl;
    	cout << "Now m_map Size is =======================" << m_map.size() << endl;
    	cout << "m_Copymap Size is " << m_Copymap.size() << endl;
    	map::iterator it1 = m_Copymap.begin(); 
    	for(it1;it1 != m_Copymap.end();it1++){
    		cout << "m_Copymap first is " << it1->first << ", "<< "m_Copymap second is " << it1->second << endl;
    	}
    	
    	
    	return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35

    实际运行结果如下:

    注:深拷贝的容器不会覆盖掉该容器中原先存在的数据,若只保存当前拷贝过来的数据,则应在拷贝前clear容器中的原先存在数据。

    vector的深拷贝方法同上。

    注:1、vecotr的内存问题:

    vector对象存在栈中,栈中是vector所存数据的地址,而数据保存在堆中。对于存储数据量较大的变量,vector存在内存问题。在不使用时,可以进行清理,清理vector内存的方法是定义一个空的vector,使用空的vector释放内存。

    vector tmp;?//空
    
    vec.swap(tmp); //待释放的vecotr变量
    
    • 1
    • 2
    • 3

    2、map的内存释放:

    map的释放也可以参考上面的vector的方法,但map的释放不是立即释放的,map会根据内存情况自己释放,若要立即释放如下:

    #include 
    #include 
    #include 
    #include 
    int main()
    {
     	map test;
    	test["Alice"] = 3;
    	test["Cindy"] = 5;
    	test["Bob"] = 7;
        map().swap(test);
        malloc_trim(0);
          
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    参考于:(6条消息) C/C++编程:STL中map内存彻底释放方法_OceanStar的博客-CSDN博客_map释放内存

  • 相关阅读:
    vite+ceisum 图片JSON 报错问题404
    小学数学学习:神奇的走马灯数 142857
    定期清理ES
    软考-代码分析
    组函数会忽略null值
    Ubuntu系统下使用docker容器配置nginx并部署前端项目
    Hive案例
    Redis -- 基础知识1
    Jenkins安装和使用
    I2C子系统-应用视角
  • 原文地址:https://blog.csdn.net/m0_67401055/article/details/126326538