c++ ,,我还有一个关于这个问题的问题。回答者说第一个
des = new char[src.size() + 1];会导致内存泄漏,因为des是一个局部变量,所以他在后面建议了另一个方法。
char* toNormalWord(const std::string& src)
{
char* des = new char[src.size() + 1];
// stuff
return des;
}但是我不明白为什么局部变量会导致内存泄漏,第一个变量和第二个变量之间有什么区别。第二个不是也使用des作为函数中的局部变量吗?我认为不同之处在于,函数接收des作为参数,或者只是创建自己。我想我不知道重要的事情,但我不知道那是什么.
发布于 2019-03-22 01:25:40
要理解句子片段的含义“只会漏出内存,因为des是一个局部变量”,我们必须了解上下文。没有明确指出的是局部变量的值没有复制到其他地方。
如果该值丢失,则分配会泄漏。
第一个和第二个有什么区别?
当在这里分配的值:des = new char[src.size() + 1];没有传递到函数的外部时,分配将无条件地泄漏到函数的末尾。
当返回值时,以后可能会删除它,从而避免泄漏。
第二个不是也使用des作为函数中的局部变量吗?
是。区别在于它的值是否返回。
发布于 2019-03-22 01:05:20
首先,des是局部变量,但它是指针变量,并且您分配(src.size() + 1)大小的内存,因此它在进程中的堆内存中分配。
检查这个网站
http://www.cplusplus.com/doc/tutorial/dynamic/
发布于 2019-03-22 11:11:32
eerorika answer是正确的,但可以扩展。
然后在本地分配内存,然后这个函数的责任是释放它。如果你把它还给别人,那你就把这个责任推给别人,这是危险的。您将遇到与您的功能相同的问题,但在其他地方:
char* toNormalWord(const std::string& src);
void processString(const std::string& src)
{
char* des = toNormalWord(src);
/* ... */
if (c == '\n') throw new std::exception("invalid character!"); //memory leak of `des`!
/* ... */
return; //memory leak of `des`!
}现在,您的内存是本地的其他功能,它应该是免费的。
避免这一切的最好方法可能是使用std::unique_ptr<char[]>
std::unique_ptr<char[]> toNormalWord(const std::string& src)
{
std::unique_ptr<char[]> des(new char[src.size() + 1]);
/* ... */
return des;
}
void processString(const std::string& src)
{
std::unique_ptr<char[]> des = toNormalWord(src);
/* ... */
if (c == '\n') throw new std::exception("invalid character!"); //no memory leak!
/* ... */
return; //no memory leak!
}有了这个编译器,将永远记住释放这个内存。
在这种特殊情况下,您可以使用std::string as suggested by barry。在某些情况下,我甚至用std::vecotr作为字符串。所有这一切都取决于这个“内存”的用法。当您需要执行很多字符串操作(如串联)时,std::string是最好的。
https://stackoverflow.com/questions/55291405
复制相似问题