c++中new和delete
是不是new运算一定要用delete,而delete删除的指针不一定是new运算申请的?书上的一个单链表删除算法是这样的boollist<T>::remove(inti,...
是不是new运算一定要用delete,而delete删除的指针不一定是new运算申请的?
书上的一个单链表删除算法是这样的
bool list<T>::remove(int i,T&x)
{ linkNode<T> *current=locate(i-1);
if(current==NULL)||current->link==NULL) return false;
linkNode<T> *del=current->link;
current->link=del->link;
x=del->data;delete del;
return true;
}
这里的delete删除的指针就不是用new操作申请的,可是以前不是学c++时说new和delete总是一对的,一起出现的吗?
谢谢大家了 展开
书上的一个单链表删除算法是这样的
bool list<T>::remove(int i,T&x)
{ linkNode<T> *current=locate(i-1);
if(current==NULL)||current->link==NULL) return false;
linkNode<T> *del=current->link;
current->link=del->link;
x=del->data;delete del;
return true;
}
这里的delete删除的指针就不是用new操作申请的,可是以前不是学c++时说new和delete总是一对的,一起出现的吗?
谢谢大家了 展开
3个回答
展开全部
你想弄懂这个问题,首先你要弄清楚数据的3种存储方式。
1。静态区: 全局变量。
2。堆: 程序执行是分配的内存
3。栈: 函数调用,局部变量。
new出来的内存就是分配到堆上的。程序执行完以后,堆上分配的内存不会被操作系统自动回收,所以你不delete掉的话,操作系统不回收,那块内存就成了没爹没娘的无业有民了,这个就叫内存泄露。
我这样说你应该知道为什么书上为什么说new和delete要成对出现了吧。分配出来的内存记得自己回收掉。
静态区和栈上面分配的内存操作系统会自动回收。所以不用delete了。
另外,我觉得你好像没有搞清楚new出来了什么东西,delete掉了什么东西。我给你举例子说。
int * pt ;
pt = new int;
这句话的意思是你先声明了一个pt指针,四个字节,放在栈里面的,然后你new了一个int形的数据放在堆里面,再把这个数据的地址赋给pt。
delete pt;
这个就是把pt指向的地址所占的内存释放掉。其实释放的就是堆上面的那个int。然后你的pt还是存在的,还在栈里面。不过你查它的值时,变成了null
这样说懂了吧。
其实你程序里面的del是在别的地方new了。
就比如:
int * A()
{
int *pt = new int;
return pt;
}
main()
{
int * ptMain;
ptMain = A();
delete ptMain;
}
这样一个过程,就像你给出的例子了。
不过,我们编程的时候尽量 谁new的谁delete,尽量避免内存泄露。
1。静态区: 全局变量。
2。堆: 程序执行是分配的内存
3。栈: 函数调用,局部变量。
new出来的内存就是分配到堆上的。程序执行完以后,堆上分配的内存不会被操作系统自动回收,所以你不delete掉的话,操作系统不回收,那块内存就成了没爹没娘的无业有民了,这个就叫内存泄露。
我这样说你应该知道为什么书上为什么说new和delete要成对出现了吧。分配出来的内存记得自己回收掉。
静态区和栈上面分配的内存操作系统会自动回收。所以不用delete了。
另外,我觉得你好像没有搞清楚new出来了什么东西,delete掉了什么东西。我给你举例子说。
int * pt ;
pt = new int;
这句话的意思是你先声明了一个pt指针,四个字节,放在栈里面的,然后你new了一个int形的数据放在堆里面,再把这个数据的地址赋给pt。
delete pt;
这个就是把pt指向的地址所占的内存释放掉。其实释放的就是堆上面的那个int。然后你的pt还是存在的,还在栈里面。不过你查它的值时,变成了null
这样说懂了吧。
其实你程序里面的del是在别的地方new了。
就比如:
int * A()
{
int *pt = new int;
return pt;
}
main()
{
int * ptMain;
ptMain = A();
delete ptMain;
}
这样一个过程,就像你给出的例子了。
不过,我们编程的时候尽量 谁new的谁delete,尽量避免内存泄露。
展开全部
1)new 和 delete 必须成对出现;
2)new 底层调用操作系统堆内存管理函数HeapAlloc来分配堆内存;
3)delete 操作符底层调用API接口函数HeapFree来释放堆内存;
可以在VC++6.0下调试,通过调用栈来分析new,delete操作涉及的与操作系统的交互过程。
2)new 底层调用操作系统堆内存管理函数HeapAlloc来分配堆内存;
3)delete 操作符底层调用API接口函数HeapFree来释放堆内存;
可以在VC++6.0下调试,通过调用栈来分析new,delete操作涉及的与操作系统的交互过程。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
当然要成对出现的,这里delete del,del指向的是以前申请的,当然也是用new申请的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询