内存泄漏:检查块类型
Memory leak: verify block type
我遇到了内存泄漏问题,最小代码如下。我的编译器是VS2008。
//haar.h
#include "stdio.h"
#include "stdlib.h"
class HaarClass
{
public:
HaarClass(void);
~HaarClass(void);
void Memory_Leak_Test();
private:
long* feature_vector_;
};
HaarClass::HaarClass(void)
{
feature_vector_ = NULL;
}
HaarClass::~HaarClass(void)
{
if (feature_vector_ != NULL) {
delete[] feature_vector_;
}
}
void HaarClass::Memory_Leak_Test(){
if (feature_vector_!=NULL) {
delete[] feature_vector_;
}
for (int i=0; i<10; i++)
{
feature_vector_ = new long[100];
if (feature_vector_!=NULL) {
delete[] feature_vector_;
}
}
}
主文件是
//main.cpp
#include <cstdio>
#include "haar.h"
int main()
{
HaarClass a;
a.Memory_Leak_Test();
return 0;
}
错误或警告是
_ASSERTE (_BLOCK_TYPE_IS_VALID (pHead -> nBlockUse));
in dbgdel.cpp Line: 52.
那么,误差是多少呢?谢谢。
当你在Memory_Leak_Test
中删除指针时,你没有将指针设置为NULL,所以你的析构函数将尝试再次删除它
void HaarClass::Memory_Leak_Test(){
if (feature_vector_!=NULL) {
delete[] feature_vector_;
}
for (int i=0; i<10; i++)
{
feature_vector_ = new long[100];
if (feature_vector_!=NULL) {
delete[] feature_vector_;
feature_vector = NULL; // <<-----
}
}
}
相关文章:
- C++ 模板类型检查标准::is_same不起作用?
- C++将一个指针分配给另一个指针时执行的类型检查
- 为什么 std::bind 静态类型检查传递给函数的参数?
- 避免使用 std::any 编写相同的重复类型检查代码
- 标准::enable_if类型检查
- 有没有办法在 C++17 中创建编译时类型映射以进行类型检查?
- 如果方法不进行类型检查,为什么C++模板匹配?
- 输入数据类型检查循环未按预期工作 (C++)
- 在编译时使用可变参数模板在 c++ 中使用参数类型检查获取函数的参数数
- 标准::键映射和/或 boost::any 类型的值的类型检查
- 类型检查的编译时失败
- 带有类型检查的可变参数模板
- 通过SWIG禁用python-c 接口的隐式类型检查代码
- C++SFINAE运算符/函数结果类型检查
- C 功能返回模板类型检查
- Dynamic_cast类型检查功能没有铸件
- C++模板元编程静态类型检查
- 仅当我提供类型检查规则时才"No type checking rule"错误
- Do模板提供类型检查
- 类型检查:查看变量是继承的还是某个类