| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3209 人关注过本帖
标题:学到链表,代码malloc的p不用free吗?请教!请教!
取消只看楼主 加入收藏
piccolo
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-12-14
收藏
 问题点数:0 回复次数:3 
学到链表,代码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
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
快速回复:学到链表,代码malloc的p不用free吗?请教!请教!
数据加载中...
 
   



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

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