类成员函数有一个指针,这个指针指向用new分配的内存,析构后会怎样(没有调用delete)
2个回答
展开全部
被开辟的内存没有释放(没有delete )就发生内存泄漏:
一般我们常说的内存泄漏是指堆内存的泄漏。堆内存是指程序从堆中分配的,大小任意的(内存块的大小可以在程序运行期决定),使用完后必须显示释放的内存。应用程序一般使用malloc,realloc,new等函数从堆中分配到一块内存,使用完后,程序必须负责相应的调用free或delete释放该内存块,否则,这块内存就不能被再次使用,我们就说这块内存泄漏了。
一般我们常说的内存泄漏是指堆内存的泄漏。堆内存是指程序从堆中分配的,大小任意的(内存块的大小可以在程序运行期决定),使用完后必须显示释放的内存。应用程序一般使用malloc,realloc,new等函数从堆中分配到一块内存,使用完后,程序必须负责相应的调用free或delete释放该内存块,否则,这块内存就不能被再次使用,我们就说这块内存泄漏了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include <iostream>
class C
{
private:
int *p;
public:
C(int i) { p=new int; *p=i;}
~C() { }
int* P() { return p;}
};
int* set_i()
{
int *ans;
C cls(100);
ans=cls.P();
return ans;
}
int main()
{
int *i;
int k;
i=set_i();
k=*i;
std::cout<<k<<std::endl;
return 0;
}
该段程序中的类C定义了一个空的析构函数,没有调用delete
试验结果,该段程序可以正常运行,输出了k=100,没有出错
说明析构之后并没有释放原先分配的内存
测试环境:dev c++ 4.9.9.2
class C
{
private:
int *p;
public:
C(int i) { p=new int; *p=i;}
~C() { }
int* P() { return p;}
};
int* set_i()
{
int *ans;
C cls(100);
ans=cls.P();
return ans;
}
int main()
{
int *i;
int k;
i=set_i();
k=*i;
std::cout<<k<<std::endl;
return 0;
}
该段程序中的类C定义了一个空的析构函数,没有调用delete
试验结果,该段程序可以正常运行,输出了k=100,没有出错
说明析构之后并没有释放原先分配的内存
测试环境:dev c++ 4.9.9.2
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询