
c语言销×(毁链表为什么一定要用二级指针,新手求教
书上源代码如下voidDestroy(structStuNode**ph)/*直接用*h的话*/{structStuNode*p;p=*ph;/*如果直接用p=h不行吗?...
书上源代码如下
void Destroy(struct StuNode**ph) /*直接用*h的话*/
{ struct StuNode*p;
p=*ph;/*如果直接用p=h不行吗?*/
while(p!=NULL)
{ *ph=p>-next;
free(p);
p=*ph;
}
printf("已删除\n");
*ph=NULL;
} 如果直接用头指针,h等于最后一个结构体的指针域,这个指针域的指针同样是个空指针,书上说需要对头指针进行“双向传递”所以要用二级指针。 展开
void Destroy(struct StuNode**ph) /*直接用*h的话*/
{ struct StuNode*p;
p=*ph;/*如果直接用p=h不行吗?*/
while(p!=NULL)
{ *ph=p>-next;
free(p);
p=*ph;
}
printf("已删除\n");
*ph=NULL;
} 如果直接用头指针,h等于最后一个结构体的指针域,这个指针域的指针同样是个空指针,书上说需要对头指针进行“双向传递”所以要用二级指针。 展开
展开全部
请注意最后一行的:*ph=NULL;
这里删除链表之后,还需要把链表的头指针置为NULL
如果这个函数的参数只是一个一级的指针,那么在函数中就没办法把链表的头指针给置为NULL了,因为C里面函数调用时,参数是传值的,传进来的一级指针和原来链表的头指针虽然具有相同的值,但是却保存在两个不同的内存单元,这时即使修改了函数里的头指针的值,外面链表的头指针却是没有收到任何影响。
这里删除链表之后,还需要把链表的头指针置为NULL
如果这个函数的参数只是一个一级的指针,那么在函数中就没办法把链表的头指针给置为NULL了,因为C里面函数调用时,参数是传值的,传进来的一级指针和原来链表的头指针虽然具有相同的值,但是却保存在两个不同的内存单元,这时即使修改了函数里的头指针的值,外面链表的头指针却是没有收到任何影响。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询