在我的应用程序中,我使用malloc()
为我的变量(unsigned char*
)分配内存,当尝试在析构函数中释放该内存时,我使用此条件来避免双重损坏。
unsigned char *wsqData;
wsqData= (unsigned char *)malloc( 10000*sizeof( unsigned char));
在我的析构函数中
if(wsqData!=NULL)
{
free(wsqData);
wsqData=NULL;
}
现在的问题是当我在析构函数之前释放内存时,这个"如果条件"无法正常工作,它再次尝试释放该变量,它会导致双重损坏错误。在这种情况下有什么问题?
在内存上调用free
不会自动将指针设置为 NULL
,因此您的条件毫无意义。您需要将wsqData
设置为NULL
释放它的任何位置。
当然,无论如何,这种情况是没有意义的,因为在NULL
指针上调用自由是安全的。
在析构函数外部释放内存时将wsqData
设置为 NULL
。但是在C++你应该使用new
和delete
。并尽量避免在析构函数以外的任何地方释放内存。
正如其他人所表示的,您还需要在每次释放它时设置为 NULL。使其成为一个函数 - 释放 var 然后将其设置为 NULL,并从析构函数和程序中的任何位置调用它。
仅供参考:这是一个悬空指针的典型示例。您需要按照建议将wsqData
设置为NULL
。