标题:删除队列中节点问题
只看楼主
gongsan
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2017-7-4
结帖率:33.33%
已结贴  问题点数:2 回复次数:8 
删除队列中节点问题
删除队列中节点,为什么先要把队列中数据项拷贝到临时变量中,再free()内存呢
搜索更多相关主题的帖子: 删除 队列 节点 free 内存 
2017-07-09 11:40
gongsan
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2017-7-4
得分:0 
直接free(Node*pt)怎么样
bool DeQueue(Item * pitem, Queue * pq)
{
    Node * pt;

    if (QueueIsEmpty(pq))
        return false;
    CopyToItem(pq->front,pitem);
    pt = pq->front;
    pq->front = pq->front->next;
    free(pt);
    pq->items--;
    if (pq->items == 0)
        pq->rear = NULL;
    return true;
}
2017-07-09 11:44
gongsan
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2017-7-4
得分:0 
static void CopyToItem(Node * pn, Item * pi)
{
    *pi = pn->item;
}
2017-07-09 11:46
gongsan
Rank: 1
等 级:新手上路
帖 子:19
专家分:0
注 册:2017-7-4
得分:0 
已解决,上面的问题答案是:保留数据能更好的让程序显示时体现良好的阅读性
2017-07-09 12:17
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
得分:1 
这是用链表实现的。
为了删除已经被弹出队列的值,所以需要free掉该节点。
但是如果free掉该节点,那么该节点也就无法访问,好吧……其实还是可以,但是是不好的习惯。
所以需要先将该节点的数据转存到函数的第一个参数,然后再free掉该节点。



09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-07-09 12:19
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:1 
保不保留数据不是用户自己的事情么~如果只是需要删除而不需要保留数据的话……~还是直接free了就可以了~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-07-09 13:33
杨阳11111
Rank: 2
等 级:论坛游民
威 望:1
帖 子:20
专家分:59
注 册:2017-5-4
得分:1 
如果你要删除节点的那个数据需要保存就把他放到一个变量里,否则也可以直接free()。大多还是看自己的需求了
2017-07-09 16:50
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:0 
感觉删除数据像一个回收站似的~干脆设计不释放空间的话把它们用平衡树保存起来~然后再用用户自行清空回收站~删除前再将其写入数据库……一般情况下似乎没有这个必要占用空间吧……~

如果要利用删除数据的话当然可以先查找再删除咯~怎么会把删除和查找这操作捆绑在一起?~

[此贴子已经被作者于2017-7-9 18:05编辑过]


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-07-09 17:40
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
得分:0 
回复 8楼 九转星河
所以这代码写的很奇葩。不封装数据这一点我都懒得吐槽了。

09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-07-09 17:52



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-479280-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.054756 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved