ArdenW 2023-02-07 20:07 采纳率: 100%
浏览 17
已结题

在while循环里,delete p是销毁当前结点

Status DestroyList(LinkList &L) // 销毁单链表
{
    LNode *p;
    while(L)
    {
        p = L;
        L = L->next;
        delete p;
    }
    return OK;
}

在while循环里,delete p是销毁当前结点,但进入下一轮循环时,p = L,为什么p还可以用,p不是销毁了吗?

  • 写回答

1条回答 默认 最新

  • 社区专家-Monster-XH 2023-02-07 20:10
    关注

    循环里面,把当前结点指针 p 保存到临时变量中,然后再把链表的头指针更新为下一个结点(L = L->next)。接着删除当前结点(delete p)。

    在下一轮循环中,链表的头指针已经更新为下一个结点,变量 p 并没有被使用到,它已经被释放了。

    所以在循环中,写的没有错。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 2月15日
  • 已采纳回答 2月7日
  • 创建了问题 2月7日