Status DestroyList(LinkList &L) // 销毁单链表
{
LNode *p;
while(L)
{
p = L;
L = L->next;
delete p;
}
return OK;
}
在while循环里,delete p是销毁当前结点,但进入下一轮循环时,p = L,为什么p还可以用,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 并没有被使用到,它已经被释放了。
所以在循环中,写的没有错。