Большинство утечек памяти появляются, когда указатель возвращенного объекта и программист забыл удалить его.
, например:
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.
}
Я спрашиваю здесь: Этот код пропускает память?(ссылки, новые, но без удаления)