首页 > 系统相关 >C++ 如何快速清空vector以及释放vector内存?

C++ 如何快速清空vector以及释放vector内存?

时间:2024-03-05 18:33:40浏览次数:26  
标签:std ary 元素 C++ wstring vector 内存 清空

1、为什么需要主动释放vector内存

  vector其中一个特点:内存空间只会增长,不会减小,援引C++ Primer:为了支持快速的随机访问,vector容器的元素以连续方式存放,每一个元素都紧挨着前一个元素存储。设想一下,当vector添加一个元素时,为了满足连续存放这个特性,都需要重新分配空间、拷贝元素、撤销旧空间,这样性能难以接受。因此STL实现者在对vector进行内存分配时,其实际分配的容量要比当前所需的空间多一些。就是说,vector容器预留了一些额外的存储区,用于存放新添加的元素,这样就不必为每个新元素重新分配整个容器的内存空间。

  在调用push_back时,每次执行push_back操作,相当于底层的数组实现要重新分配大小;这种实现体现到vector实现就是每当push_back一个元素,都要重新分配一个大一个元素的存储,然后将原来的元素拷贝到新的存储,之后在拷贝push_back的元素,最后要析构原有的vector并释放原有的内存。


2、怎么释放vector的内存

  A、对于数据量不大的vector,没有必要自己主动释放vector,一切都交给操作系统。

  B、但是对于大量数据的vector,在vector里面的数据被删除后,主动去释放vector的内存就变得很有必要了!

  由于vector的内存占用空间只增不减,比如你首先分配了10000个字节,然后erase掉后面9999个,留下一个有效元素,但是内存占用仍为10000个。所有内存空间是在vector析构时候才能被系统回收。empty()用来检测容器是否为空的,clear()可以清空所有元素。但是即使clear(),vector所占用的内存空间依然如故,无法保证内存的回收。如果需要空间动态缩小,可以考虑使用deque。如果vector,可以用swap()来帮助你释放内存。

3、示例代码

  新建一个控制台程序,把代码运行起来看输出,且看代码:

 1 #include <iostream>
 2 #include <vector>
 3 #include <string>
 4 #include <Windows.h>
 5 #include <Psapi.h>
 6 #pragma comment(lib, "Psapi.lib")
 7  
 8 using namespace std;
 9  
10 //GetCurPorcessMemory
11 bool GetCurProcessMemory(HANDLE handle, std::wstring& workingSize, std::wstring& peakWorkingSize)
12 {
13     //HANDLE handle = GetCurrentProcess();
14     PROCESS_MEMORY_COUNTERS pmc;
15     if (GetProcessMemoryInfo(handle, &pmc, sizeof(pmc)))
16     {
17         int size = pmc.WorkingSetSize/1024;
18         wchar_t buf[10] = {0};
19         _ltow(size, buf, 10);
20         workingSize = std::wstring(buf);
21  
22         size = pmc.PeakWorkingSetSize/1024;
23         _ltow(size, buf, 10);
24         peakWorkingSize = std::wstring(buf);
25  
26         return true;
27     }
28     return false;
29 }
30  
31 int _tmain(int argc, _TCHAR* argv[])
32 {
33     std::wstring wszWorking, wszPeakWorking;
34     vector<string> ary;
35  
36     for (int i=0; i<1000000; i++)
37     {
38         ary.push_back("hello vector");
39     }
40  
41     wchar_t wch;
42     wcin >> wch;
43  
44     GetCurProcessMemory(GetCurrentProcess(), wszWorking, wszPeakWorking);// 此时检查内存情况
45     wcout << "Working : " << wszWorking.c_str() << " PeakWorking : " << wszPeakWorking.c_str() << endl;
46  
47     wcin >> wch;
48  
49     //
50     ary.clear();
51     wcout << "vector clear" << endl;
52     wcout << "vector capacity " << ary.capacity() << endl;    
53     GetCurProcessMemory(GetCurrentProcess(), wszWorking, wszPeakWorking);// 此时再次检查
54     wcout << "Working : " << wszWorking.c_str() << " PeakWorking : " << wszPeakWorking.c_str() << endl;
55  
56     wcin >> wch;
57     //vector<string>(ary).swap(ary);
58     ary.swap(vector<string>(ary));    
59     wcout << "vector swap" << endl;
60     wcout << "vector capacity " << ary.capacity() << endl;// 此时容量为0    
61     GetCurProcessMemory(GetCurrentProcess(), wszWorking, wszPeakWorking);// 检查内存
62     wcout << "Working : " << wszWorking.c_str() << " PeakWorking : " << wszPeakWorking.c_str() << endl;
63  
64     wcout << "vector size : " << ary.size() << endl;//0
65  
66     //getchar();
67     system("pause");
68  
69     return 0;
70 }

 

标签:std,ary,元素,C++,wstring,vector,内存,清空
From: https://www.cnblogs.com/ybqjymy/p/18054632

相关文章

  • Qt QVector数据清理和内存清理
    原因在处理大数据时,发现QVector直接用clear后台查看程序所占用的内存并没有下降QVector数据清理1QVector<int>example_vec;2example_vec.clear();QVector内存清理1QVector<int>example_vec;2example_vec.shrink_to_fit();//程序运行到此处时内存才被降下去QV......
  • C++ 职工信息管理系统项目的二次开发 2252423 ywx
    来源:同学大二下的期末大作业:网上购书系统项目。运行环境:VisualStudio2022①项目结构:②运行结果截图:主菜单界面:功能选择界面:工资总额输出界面:平均工资输出界面:显示输出界面:增加正式员工界面:增加临时员工界面:修改数据界面:③主要问题:查询功能未完善,有时会出现......
  • 基于c/c++的公司职工管理系统软件的二次开发
    引言:经过在网络上的广泛搜索和比较,我了解了一款基于C/C++的公司职工管理系统软件,这款软件在基本功能方面表现相当完善,能够满足日常的使用需求。然而,在实际使用过程中,我也发现它存在一些问题和不足,所以我决定对该软件进行二次开发。原始代码:点击查看代码**main.cpp**#include......
  • 超市管理系统C++
    超市管理系统(摘自大一小学期同学作品)一、C++语言程序设计------《超市管理系统设计》问题分析这个超市商品管理系统的主要功能是为超市的管理层提供货物查询及银行转帐货物管理服务,方便超市管理层工作,提高管理层的服务质量和服务效率。超市商品的信息必须经由各部门及人事初及......
  • 可恶的vector
    前言当你使用了\(vector\)你一定觉得这是一个非常实用,非常好用的数据结构。当你这样想的时候,你就陷入了\(vector\)的圈套。正文注意事项vector的定义与赋值操作当你定义了一个指定大小的\(vector\),如:vectorv(N)此时容器中的所有元素都被赋值为\(0\)。如果你使用了v.push_ba......
  • 从Python语言的角度看C++的指针
    技术背景从一个PythonCoder的角度来说,其实很羡慕C++里面指针类型的用法,即时指针这种用法有可能会给程序带来众多的不稳定因素(据C++老Coder所说)。本文主要站在一个C++初学者的角度来学习一下指针的用法,当然,最好是带着一定的Python基础再去学习C++的逻辑,会更容易一些。内存地址赋......
  • C++面试,实现memcpy,strcpy这2个函数的功能
    `strcpy`和`memcpy`都是用于内存复制的函数,但它们之间有几个关键的区别:1.**复制的对象**:-`strcpy`主要用于复制字符串,它将从源字符串的起始位置开始复制字符,直到遇到源字符串的空字符('\0'),然后将空字符也复制到目标字符串中,表示字符串的结束。-`memcpy`则是通用的内存复......
  • 37vector容器与API
    vector容器与API#include<iostream>#include<vector>usingnamespacestd;/*vector容器:向量容器底层数据结构:动态开辟的数组,每次以原来空间2倍进行扩容vector<int>vec;增加:vec.push_back(20);末尾添加元素O(1)导致容器扩容vec.insert(it,20);it迭代器指向的位......
  • 36C++语言级的四种类型转换
    C++语言级的四种类型转换const_cast:去掉常量属性的类型转换static_cast:提供编译器认为安全的类型转换reinterpret_cast:类似C风格的强制类型转化dynamic_cast:主要用在继承结构中,可以支持RTTI类型识别的上下转换#include<iostream>usingnamespacestd;classBas......
  • 39vector, deque, list之间的对比
    vector,deque,list之间的对比vector的特点:动态数组内存是完全连续的扩容:2倍形式扩容,扩容时要开辟新的内存空间,并将数据拷贝list的特点:双向循环链表内存是不连续的没有扩容需求deque的特点:参考动态开辟的二维数组空间内存分段连续第二维是固定长度的数组......