标题:指针释放函数free()的一处使用
只看楼主
SMRen
Rank: 2
等 级:论坛游民
帖 子:9
专家分:42
注 册:2018-3-9
结帖率:100%
已结贴  问题点数:20 回复次数:5 
指针释放函数free()的一处使用
正在试图编写一个链栈,结构体定义如下:
typedef struct node
{
    char data[10];
    struct node *pre;
}Linkstackelem;

typedef struct{
    Linkstackelem *top;
    int length;
}Linkstack;

问题出在Pop函数中:
int Pop_Linkstack(Linkstack *S, char *dat)
{
    Linkstackelem *tmp;
    if(S->length == 0)
    {
        printf("ERROR!\n");
        return ERROR;
    }
    tmp = S->top->pre;
    strcpy(dat, S->top->data);
    //free(S->top->pre);****************这句没被注释前程序执行会出错,导致S->top归零,注释后就好了
    free(S);
    S->top = tmp;
    S->length --;
    return OK;
}

求教,函数中S->top指向一个栈节点,这个节点中的pre也是一个指针,那么用free函数释放这个指针应该是对的;百度的意见就是对结构体指针要一层一层往外释放,然后我就不明白我怎么错了,求指点
搜索更多相关主题的帖子: 指针 释放 函数 free top 
2018-03-17 11:28
SMRen
Rank: 2
等 级:论坛游民
帖 子:9
专家分:42
注 册:2018-3-9
得分:0 
Linkstack.rar (1.25 KB)
这是完整程序
2018-03-17 11:56
童生
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:205
专家分:455
注 册:2018-3-7
得分:0 
    free(S);
    S->top = tmp;
    S->length --;

2018-03-17 12:17
langlixing
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2018-3-16
得分:0 
我也是不得好懂,我觉得百度说的有道理,因位结构体指针就好像快递一样应该是一层包一层的,逻辑上是没法先拆里面再拆外面的吧,所以要一层层释放
2018-03-17 12:31
lanke711
Rank: 9Rank: 9Rank: 9
来 自:流浪在天国之路
等 级:蜘蛛侠
威 望:7
帖 子:317
专家分:1437
注 册:2015-7-16
得分:20 
free(S->top->pre);pre是指向的前驱节点?如果是。为何你要去释放它?这和你一层一层释放资源思路不是冲突了吗?

普通人之所以普通,是因为他们普遍有一个通病,那就是认为自己永远普通。
千夫所指,我亦坚持。就算被所有人误解,我也照样守护这一切。
我们总是觉得,这些灵魂的表情,傲慢自大,目中无人,其实,真正目中无人的是我们。它们傲慢的不过是表情,而我们傲慢的却是行为!
记得,是为了忘记!
只要想着有那么一天,我就能忍受现在的每一天!
灾难并不可怕,可怕的是心中没有了希望。
你以为我在天堂,其实我正在路上。
当你觉得自己走不到终点的时候,请不要放弃。或许你的对手也是这种感觉。
2018-03-17 13:34
SMRen
Rank: 2
等 级:论坛游民
帖 子:9
专家分:42
注 册:2018-3-9
得分:0 
回复 5楼 lanke711
我明白了,难怪每次返回后S->top都变成0x0了;多谢指点!
2018-03-17 18:29



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




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

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