大多数内存泄漏出现在对象指针返回时程序员忘记删除它的情况下。
例如:
class my_class
{
...
};
my_class* func1()
{
my_class* c = new my_class;
return c;
}
int main()
{
my_class* var1 = func1();
...
// Programmer forgot delete the var1: delete var1;
// -- or --
// Doesn't know 'delete[] var1;' is correct or 'delete var1;'.
}
有些内存泄漏是由于程序员创建了一个对象的指针,但忘记将其删除。
例如:
class my_class
{
...
};
void func2(my_class* p)
{
...
}
int main()
{
my_class* var3 = new my_class;
func2(var3);
// Does func2 deletes var3? Programmer doesn't know.
// -- or --
// Programmer forgot delete the var3.
}
我使用一种方法来解决内存泄漏问题,但在复杂情况下我不确定是否有效。
我的方法是:除了一个地方外,不要使用任何指针,而是使用引用代替指针。
例如:
class my_class
{
...
};
my_class& func1()
{
my_class* c = new my_class; // except one place.
return *c;
}
void func2(my_class& p)
{
...
}
int main()
{
my_class& var1 = func1();
my_class var2 = func1();
my_class var3;
func2(var3);
// There is nothing to forget.
}
使用引用而不是指针,能够解决内存泄漏问题吗?
这是解决内存泄漏的好方法吗,还是有更好的方法?
编辑:
对于这个问题的某些回答认为下面的代码存在内存泄漏。
因为这是一个新问题,我将它单独提出来了。
class my_class
{
...
};
my_class& func()
{
my_class* c = new my_class;
return *c;
}
int main()
{
my_class& var1 = func();
// I think there is no memory leak.
}
my_class* c = new my_class; return *c;
不会导致内存泄漏。当(在这种情况下)var2
超出范围时,析构函数可能会被调用,但是内存可能不会被释放。 - Chris Frederick