c++ delete函数释放内存了吗?

classParent{public:Parent();~Parent();voidsetX(intx);intgetX();private:intx;};voidPar... class Parent
{
public:
Parent();
~Parent();
void setX(int x);
int getX();
private:
int x;

};

void Parent::setX(int x)
{
this->x=x;
}
int Parent::getX()
{
return this->x;
}

一个很普通的类
然后mian函数我调用的时候结果很让我费解
Parent *p=new Parent();
p->setX(5);
cout<<p->getX();
delete(p);
cout<<p->getX();

结果输出了 2个5 我以为会报错的 . delete没有把 x 的内存释放掉为什么?
为什么 x还存在内存中 该如何释放
展开
 我来答
hutaow
推荐于2016-08-27
知道答主
回答量:1
采纳率:0%
帮助的人:0
展开全部
delete(p)确实已经释放了p所指向的那块内存,但所谓释放并不是清空,而是把那块内存重新回收到系统中,告诉系统这块内存又可以重新分配了。可以参考格式化和低级格式化的操作效果。
正确的做法是delete完之后还应当将指针置空。
luyiyuan129
2010-07-02
知道答主
回答量:9
采纳率:0%
帮助的人:1.1万
展开全部
delete(p);
只表示p所指向的内存块的所有权,不归p所管了,但是内存里的值还在,
所以你delete完之后,取内存里的值,当然还在。

所以为什么内存释放之后一定要将指针置空,防止野指针出现

正确做法:
delete(p);
p = NULL;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
xm520333444
2010-07-02
知道答主
回答量:7
采纳率:0%
帮助的人:0
展开全部
如果类的对象里没有用new创建的数据成员,那么你就不需要担心类所占的空间 ,因为在这个对象的生命周期结束之后就会自己回收内存
如果是通过new那么 内存是在堆上分配 则使用delete删除类中的用new开辟的数据成员,其他的不用管,自动释放。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
paipaijiabin
2010-07-02
知道答主
回答量:9
采纳率:0%
帮助的人:0
展开全部
你已经取消了指针,但是指针指向的内存中的数据还在;
delete(p);和没写一样
直接p=NULL;就好了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
簡簡單單ゾ
2010-07-02 · 超过33用户采纳过TA的回答
知道答主
回答量:100
采纳率:0%
帮助的人:71.2万
展开全部
貌似是你的构造函数和析构函数的问题;
照你的代码 我在vc 6.0下 编译不通过,两个错误;
#include <iostream.h>
class Parent
{
public:
Parent() //构造函数 你只声明 没有定义
{
}
~Parent()
{
}
void setX(int x);
int getX();
private:
int x;

};

void Parent::setX(int x)
{
this->x=x;
}
int Parent::getX()
{
return this->x;
}

void main()
{
Parent *p=new Parent();
p->setX(5);
cout<<p->getX();
delete(p);
cout<<p->getX();
}
这是改了的代码 可以delete
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式