内存泄漏,c++的向量回推
Memory leak, vector pushback c++
我有一个类Bar
,它的构造函数初始化了一个类型为Foo
(另一个类)的std::vector
。
Bar.cpp
Bar::Bar(int n) {
for(int i = 0; i < n; i++) {
Foo foo;
foo.somefunction(i);
vec.push_back(foo) //this should insert foo into the vector
}
}
Bar.h
class Foo;
class Bar {
std::vector<Foo> vec;
};
当我调试时,构造的第一次迭代工作得很好。foo
已创建,foo.somefunction()
运行正常,foo
被压入vec
第二次迭代似乎也工作得很好,但是当它返回开始第三次迭代时,程序崩溃了。
我得到_BLOCK_TYPE_IS_VALID(pHead->nBlockUse)
错误和HEAP CORRUPTION DETECTED
.
Foo
是一个包含动态创建的数组的类,没有什么特别的。像这样:
Foo::Foo() {
solution = new float[size];
// some function that initializes the elements of solution
}
和常规析构函数~Foo() {delete [] solution;}
。我认为问题不是来自Foo
。
很可能您没有正确实现copy constructor
和operator =
,并且您正在双重删除solution
。如前所述,你还应该阅读"三的规则"。
c++标准容器存储副本,所以当你执行push_back
时,你是在复制。
看起来您没有在类Foo中实现复制构造函数。在Bar构造函数中,每次迭代都创建Foo的新实例,并在迭代结束时销毁它。因此,在Foo中分配的内存被销毁,但是将Foo的实例复制到vector的默认复制构造函数并没有复制你用"new"分配的内存,只是复制了指针。所以每次迭代后,每个向量元素都被破坏了。假设vector在开始时为您的对象分配了一些内存。然后,当缓冲区中没有空间了,并且不能再增加缓冲区时,vector会分配新的内存,并进行另一次复制操作。当复制操作完成时,旧的缓冲区需要被释放,vector销毁旧缓冲区中的所有对象,每个对象的析构函数将在损坏的指针上调用delete[]。
- 写入向量<向量<bool>>
- 函数向量_指针有不同的原型,我可以构建一个吗
- std::向量与传递值的动态数组
- 将值指定给向量(2D)的向量中的某个位置
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 如何使用向量的template_back函数
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何通过派生类函数更改基类中的向量
- C++从另一个类访问公共静态向量的正确方法是什么
- 如何将ampl中的集合表示为c++中的向量
- 变量没有改变?通过向量的函数调用
- 迭代时从向量和内存中删除对象
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 计算排序向量的向量中唯一值的计数
- 矩阵向量乘法(cublasDgemv)返回零
- 一对向量构造函数:初始值设定项列表与显式构造
- 将结构向量排序为子组
- 在C++中调整向量中的索引
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么