C 内存管理问题,std :: vector nevere rase内存超出范围
c++ memory managment problem, std::vector nevere relase memory out of scope
我对这个简单的代码感到非常困惑。为什么此代码可以发布分配的内存。
double *a;
for(int i = 0 ; i < 1000000 ; i++)
{
if(1){
a = new double ;
}
if(1){
delete a;
}
}
但是此代码无法删除所有分配的内存。
std::vector<double *>rubberList ;
for(int i = 0 ; i < 1000000 ; i++)
{
rubberList.push_back(new double);
//delete rubberList[i];
}
for(unsigned long j = 0 ; j < 1000000 ; j++)
{
delete rubberList.at(j);
}
,当删除分配器块中的项目正确删除内存。
for(int i = 0 ; i < 1000000 ; i++)
{
rubberList.push_back(new double);
delete rubberList[i];
}
tnx
您发布的中间示例确实会释放所有内存。为了获得更多证明,我对您的代码进行了编译,并使用valgrind
进行运行:
== 5829 == memcheck,内存错误检测器
== 5829 ==版权(c)2002-2017和gnu gpl'd,Julian Seward等人。
== 5829 ==使用valgrind-3.13.0和libvex;重新运行-H用于版权信息
== 5829 ==命令:test
== 5829 ==
== 5829 ==
== 5829 == HEAP摘要:
== 5829 ==在出口时使用:0块中的0字节
== 5829 ==总堆用法:30个Allocs,30 Frees,4,065字节分配
== 5829 ==
== 5829 == 释放了所有堆块 - 无泄漏
== 5829 ==
== 5829 ==对于检测到的错误计数和抑制错误,重新运行:-v
== 5829 ==错误摘要:0来自0上下文的错误(抑制:0)
您发布的代码确实清理了内存。它唯一不同的事情可能是使用更多的内存,因为您在中间分配了一吨双打,但在第一个中只有一个双打。
您在哪里证据表明它不会删除内存?还是您的意思是其他?
相关文章:
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- C 内存管理问题,std :: vector nevere rase内存超出范围