| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3231 人关注过本帖
标题:学到链表,代码malloc的p不用free吗?请教!请教!
只看楼主 加入收藏
piccolo
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-12-14
收藏
 问题点数:0 回复次数:6 
学到链表,代码malloc的p不用free吗?请教!请教!
typedef struct _node{
    int value;
    struct _node *next;
    struct _node *prev; //previous
}Node;

int main(int argc, char const *argv[])  
{
    //input number
    int number;
    Node *head = NULL;
    Node *rlast; //reallast
    do
    {
        scanf("%d", &number);
        if(number != -1)
        {
            Node *p = (Node*)malloc(sizeof(Node));
            p->value = number;
            p->next = NULL;
            p->prev = NULL;
            
            //find the last
            Node *last = head;
            if(last)
            {
                while(last->next)
                {
                    last = last->next;
                }
                p->prev = last;
                last->next = p;
            }
            else
            head = p;
            rlast = p;
            printf("%p %p ", rlast, p); //发现rlast和p的地址一样,每次都重新申请p,之前的p空间占着不用了(没free)?
        }
    }while(number != -1);
   
    //output number
    Node *a;
    for(a = rlast;a;a = a->prev)
    {
        printf("%d ", a->value);
    }
   
    return 0;
}

[此贴子已经被作者于2016-12-14 22:31编辑过]

搜索更多相关主题的帖子: previous number 
2016-12-14 22:26
piccolo
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-12-14
收藏
得分:0 
懂了
2016-12-14 22:54
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
我记得以前把scanf写进if里面是要free输入结束条件那个的,如果把scnaf写在if外面就先判断,再申请空间,那就没有多申请空间,每个空间的数据都是有用的,因此不用free了~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2016-12-14 23:19
marlow
Rank: 6Rank: 6
等 级:侠之大者
威 望:2
帖 子:125
专家分:419
注 册:2016-7-18
收藏
得分:0 
回复 2楼 piccolo
////printf("%p %p ", rlast, p); //发现rlast和p的地址一样,每次都重新申请p,之前的p空间占着不用了(没free)?
你这里是添加节点的循环,所以每添加一个节点就重新申请P,P的空间应在删除节点或清空链表中释放,但你这个程序中没有相关的代码(功能),
所没就没使用到free()了,这样会导致内在泄漏吧?不知道程序关闭会不会自动释放这些内在。。。

一切都在学习、尝试、摸索中
2016-12-15 09:47
piccolo
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-12-14
收藏
得分:0 
回复 3楼 九转星河
恩,谢谢
2016-12-15 10:58
piccolo
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-12-14
收藏
得分:0 
回复 4楼 marlow
每个p都有存放数据,不用free
2016-12-15 10:59
chenhaihao
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2016-12-9
收藏
得分:0 
我们也刚好学到这里,可我也不懂......
2016-12-16 11:13
快速回复:学到链表,代码malloc的p不用free吗?请教!请教!
数据加载中...
 
   



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

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