首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >释放双向链表

释放双向链表
EN

Stack Overflow用户
提问于 2021-01-02 20:04:57
回答 1查看 60关注 0票数 1

我正在尝试释放一个双向链表,我的问题是,我是否还需要释放每个节点中的所有数据和指针。谢谢。

功能:

代码语言:javascript
复制
static void free_list(Room *head, Room *head2) {
    Room *tmp = head;
    Room *tmp2 = head2;
    Room *store;
    Room *store2;
    tmp = head2;
    tmp2 = head;

    printf("\nFreeing trap list...\n");
    sleep(2);
    while (tmp != NULL) {
        store = tmp->pNext;
        free(tmp);
        tmp = store;
    }

    printf("\nFreeing rooms list...\n");
    sleep(2);
    while (tmp2 != NULL) {
        store2 = tmp2->pNext;
        free(tmp2);
        tmp2 = store2;
    }
}

结构:

代码语言:javascript
复制
typedef struct Room {
    struct Room *forward;
    struct Room *left;
    struct Room *right;
    struct Room *previous;
    struct Room *pPrev;
    struct Room *pNext;
    Room_Type Room_Type;
    bool emergency_call;
} Room;

那么,在本例中,我还需要释放前向指针和其他类型的指针吗?headhead2是两个不同的指针,每个指针指向两个不同列表的开始。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-02 20:20:32

这种定义容器的方式非常令人困惑:

代码语言:javascript
复制
typedef struct Room{
  struct Room* forward;
  struct Room* left;
  struct Room* right;
  struct Room* previous;
  struct Room* pPrev;
  struct Room* pNext;
  Room_Type Room_Type;
  bool emergency_call;
} Room;

分而治之:

代码语言:javascript
复制
typedef struct Node {
  struct Node* pPrev;
  struct Node* pNext;
  Room_Type Room_Type;
  bool emergency_call;
} Node;

typedef struct List {
  struct Node* pHead;
  struct Node* pTail;
} List;

使用这种方法,一个循环就足够了:

代码语言:javascript
复制
void free_list(List *list)
{
    Node *node = list->pHead;

    while (node != NULL)
    {
        Node *next = node->pNext;

        free(node);
        node = next;
    }
    free(list);
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65538889

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档