在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不是销毁了吗?

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

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

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