关于vector的释放问题

本文主要讨论了C++初学者在使用vector时遇到的内存管理问题。作者在编写数据处理程序时,发现程序在处理大量数据时出现内存不足或读取内存失败的错误。经过排查,发现是vector类型的变量在链表释放后未自动释放,导致内存泄露。解决方案是手动调用clear和shrink_to_fit方法来确保vector内存得到释放。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#define NEW(TYPE) (TYPE *)calloc(1,sizeof(TYPE));

typedef struct man
{
	int a;
	int b;
	vector<int> tmp;
}man;


void test(vector<int> &c)
{
	vector<int> ac(5);
	c = ac;
	for (int i = 0; i != 5; ++i)
	{
		ac[i] = i + 1;
	}
	c = ac;
}
void test1(man*h)
{
	vector<int> cc(5);
	test(cc);
	man*tmp = nullptr;
	tmp = h;
	tmp->tmp = cc;
}
int main(void)
{
	man*head = nullptr;
	head = NEW(man);
	test1(head);
	head->tmp.clear();
	head->tmp.shrink_to_fit();
	free(head);
	head = nullptr;
	return 0;
}


作为一名c++入门的菜鸟,学习的路上难免遇到些问题。


最近写一个数据处理的小程序,其中用到了链表,结构体(其中有个vector成员变量)等;程序写完兴致勃勃的去运行,程序是可以跑了但是跑的数据量大了就出现了类存不足或读取内存空间失败的错误。。。。。。


自己还以为代码中出了错,默默的找了好久。。。(硬是没找出来),最后在网上一查,快哭了内存泄露。。。在查找内存泄露相关内容,都是new或malloc等申请空间后没有释放。。。吐了一波槽


自己还以为代码中出了错,默默的找了好久。。。(硬是没找出来),最后在网上一查,内存泄露。。。在查找内存泄露相关内容,都是new或malloc等申请空间后没有释放。

但是我自己的程序当中用了比较多的vector类型的数组变量,在链表中也包括了(本来变量在其生命周期结束后会自动释放的)


从上面的图中可以看出变量CC在test1的生命周期结束后是自动释放了(它对应地址中的数据被释放了)

但是我发现在释放链表时,其中的vector类型的变量在链表释放后不会自动释放(哭死。。。)——见下图



从上面可以看出,head是被释放了,但开始head->tmp对应地址中的值并没有被释放。。。。

还是默默的用clear 加shrink_to_fit释放吧


——ps:小白第一篇,有错望大神们指正吐舌头

### C++ 中 `vector` 正确释放内存与资源管理的最佳实践 #### 使用析构函数自动清理 当不再需要 `std::vector<int>` 对象时,其生命周期结束会触发默认析构函数执行。该过程能够确保所有已分配给向量内部数组的空间被适当地回收[^1]。 ```cpp { std::vector<int> vec; // 向vec添加元素... } // 当作用域结束时,vec及其持有的资源会被销毁并释放 ``` #### 明确清空内容而不立即减少容量 如果希望保留当前预留空间以便后续重用,则可以仅清除现有条目而不停留于缩小实际占用字节数: ```cpp // 清除所有元素但保持预分配大小不变 myVector.clear(); assert(myVector.empty()); ``` #### 手动收缩至合适尺寸 为了使容器的实际存储匹配逻辑长度,在某些情况下可显式请求调整底层数组规模: ```cpp void shrink_to_fit_example(){ std::vector<double> data(10); // ...操作data... // 提示编译器尝试优化内存使用效率 data.shrink_to_fit(); } ``` #### 利用交换技巧完全腾退 对于那些确实想要即时放弃整个缓冲区的情况——即使这可能导致频繁重新配置新区域的风险——可以通过标准库提供的swap惯用法达成目的[^5]: ```cpp template<typename T> void release_vector_memory(std::vector<T>& v){ using namespace std; vector<T>().swap(v); // 创建临时空对象并与原实例互换所有权 } ``` 上述方法遵循现代C++编程中的RAII原则(Resource Acquisition Is Initialization),即通过构造和破坏局部实体来控制资源获取与释放的时间点,从而有效预防潜在泄漏问题的发生.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值