| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付学习型 ASP/PHP/ASP.NET 主机 30元/年
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY 
共有 1254 人关注过本帖
标题:[求助]怎样销毁一个线性表?
收藏  订阅  推荐  打印 
x21feng
Rank: 1
等级:新手上路
帖子:9
积分:190
注册:2006-3-20
[求助]怎样销毁一个线性表?

如果要销毁一个带头结点的线性表,是直接将head->next置空(即head->next=NULL),还是要全部元素都要使用free()函数将他们释放,又或者是释放head->next就可以了.又或者都不是上边的方法,望高手指点!!
搜索更多相关主题的帖子: 线性表  head  next  结点  
2006-3-27 12:20
sunnvya
Rank: 12Rank: 12Rank: 12
等级:贵宾
威望:17
帖子:1094
积分:11142
注册:2005-11-23

动态分配空间的话,
那些空间一般都得销毁!
而将head->next置空(即head->next=NULL)只是让链表置空,找不到这个链表而已!

http://www.deerz.cn 第二站>>>提供源码下载
2006-3-27 12:46
qzt040613
Rank: 2
等级:注册会员
威望:6
帖子:63
积分:830
注册:2006-3-15

free(S),S是链表名

天地无极,我本逍遥!
2006-3-28 12:26
stnlcd
Rank: 3Rank: 3
等级:中级会员
帖子:176
积分:2310
注册:2004-11-21

全部元素都要释放,可以写为递归程序:

typedef struct List {
ListType data;
struct List* next;
}List,*PList;

可以写为:
void Destroy_List(PList list) {
if(list) {
Destroy_List(list->next);
free(list); list=NULL;
}
}
list=NULL;是必须要加的,否则后果自负。

要让一个男人破产,请给他一架相机,要让一个男人倾家荡产,请给他一架望远镜。
2006-3-29 09:18
stnlcd
Rank: 3Rank: 3
等级:中级会员
帖子:176
积分:2310
注册:2004-11-21

绝对不可以写成free(S),S是链表名的形式!!


要让一个男人破产,请给他一架相机,要让一个男人倾家荡产,请给他一架望远镜。
2006-3-29 11:03
x21feng
Rank: 1
等级:新手上路
帖子:9
积分:190
注册:2006-3-20

以下是引用stnlcd在2006-3-29 9:18:00的发言:
全部元素都要释放,可以写为递归程序:

typedef struct List {
ListType data;
struct List* next;
}List,*PList;

可以写为:
void Destroy_List(PList list) {
if(list) {
Destroy_List(list->next);
free(list); list=NULL;
}
}
list=NULL;是必须要加的,否则后果自负。


如不加上list=NULL;该指针还是指向原来的空间,会发生意外.

2006-3-29 19:46
xuchao501
Rank: 1
等级:新手上路
帖子:2
积分:120
注册:2008-3-27

同意4,6
2008-3-27 08:53
同生缘
Rank: 1
等级:新手上路
帖子:25
积分:396
注册:2007-11-18

malloc 与free可以说是  共存的。
2008-8-14 23:30
geninsf009
Rank: 3Rank: 3
等级:中级会员
威望:1
帖子:265
积分:3190
注册:2008-8-16

如果从一个程序完美的角度来说,还是要释放所有结点的内存为好,
参考代码:
template <class T>
void  LinkedList<T>::makeEmpty()
{
     LinkedNode<T>* ptr=head;//游标指针
     LinkedNode<T>* pre;     //指向ptr前个结点的指针
     while(ptr!=NULL)
     {
          pre=ptr;           //保存前个结点指针
          ptr=ptr->link;     
          delete pre;
     }
}
一般在析构函数里调用它...
2008-8-16 11:18
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.285721 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved