0

在我的应用程序中,我使用 为我的变量 ( unsigned char*)malloc()分配了内存,当尝试在析构函数中释放该内存时,我使用此条件来避免双重损坏。

unsigned char *wsqData;
wsqData= (unsigned  char *)malloc( 10000*sizeof( unsigned char));

在我的析构函数中

  if(wsqData!=NULL)
  {
      free(wsqData);
      wsqData=NULL;
  } 

现在的问题是,当我在析构函数之前释放内存时,这个“如果条件”无法正常工作,它再次尝试释放该变量,导致双重损坏错误。在这种情况下有什么问题?

4

4 回答 4

5

调用free内存不会自动将指针设置为NULL,因此您的条件毫无意义。你需要设置wsqDataNULL你释放它的任何地方。

当然,无论如何,条件都是没有意义的,因为对NULL指针调用 free 可以保证是安全的。

于 2012-04-23T08:19:31.320 回答
3

当您在析构函数之外释放内存时,您需要设置wsqDataNULL。但在 C++ 中,您应该使用newand delete。并尽量避免在析构函数之外的任何地方释放内存。

于 2012-04-23T08:19:08.247 回答
0

正如其他人指出的那样,您还需要在每次释放它时设置为 NULL。使它成为一个函数 - 释放 var 然后将其设置为 NULL,并从析构函数和程序中的任何位置调用它。

于 2012-04-23T08:29:15.873 回答
0

仅供参考:这是悬空指针的经典示例。您需要wsqData按照NULL建议设置。

于 2012-04-23T09:23:36.507 回答