STL deque pop_front()会自动回收内存吗
Will STL deque pop_front() automatically recycle memory?
我有一个程序,在其中我收集一些数据并将它们临时存储在deque 中
typedef vector<float> floatVector;
...
floatVector * currRecord;
deque<floatVector *> data;
...
...
for (...)
{
...
currRecord = new floatVector(10);
data.push_back(currRecord);
}
稍后,我想将数据保存到文件
while (data.size() > 0)
{
for (int i=0; i < 10; i++)
{
fprintf(fPtr, "%lft", data[0]->at(i) );
}
fprintf(fPtr,"n");
data.pop_front();
}
所以,我的问题是,这个程序会导致内存泄漏吗?我使用new
运算符为每个currRecord
向量分配内存。deque pop_front
功能会自动回收内存吗?或者我需要放吗
delete [] data[0]
之前
data.pop_front();
此外,如果data
是一个向量而不是一个deque,那么一切都会一样吗?谢谢
您有一个std::deque
指针,每个指针都拥有一个资源(内存)。调用pop_front()
将从容器中删除指针,但不会释放指针所拥有的内存。由于您使用new
分配内存,因此还必须调用delete
。如果容器是std::vector
,则情况不变。
如果您更改为std::deque<floatvector>
或像std::shared_ptr
这样的智能指针容器,就可以避免内存泄漏。
请注意,在调用new
时没有使用[]
,所以使用不带方括号的普通delete
。
相关文章:
- 将字符串存储在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的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- Stack.pop 内存管理
- 队列中pop()上的内存浪费