C语言问题(数据结构)
voidtest(LNode*L){LNode*p=L->next;L->next=NULL;while(p!=NULL){...}}第一句和第二句作用下,就会导致p==...
void test(LNode *L)
{
LNode *p = L -> next;
L -> next = NULL;
while(p != NULL)
{
...
}
}
第一句和第二句作用下,就会导致p == NULL, 使得while括号里的条件永不满足,但事实并非如此,为什么? 展开
{
LNode *p = L -> next;
L -> next = NULL;
while(p != NULL)
{
...
}
}
第一句和第二句作用下,就会导致p == NULL, 使得while括号里的条件永不满足,但事实并非如此,为什么? 展开
1个回答
展开全部
LNode *p=L->next 定义一个结构体指针p,使其指向L->next中记录的地址,假设L->next中记录的地址为0xA,此时p中的内容就是0xA。注意,这一行为是拷贝,即将L->next中的内容拷贝到p中;
L->next=NULL 令L->next=NULL,此时L->next中记录的地址变为0x0,但这一操作并不影响到指针p,p中记录的内容是一份拷贝,它的值仍然是0xA。所以,不存在p==NULL,除非在执行第一条语句时L->next本身就为NULL。
L->next=NULL 令L->next=NULL,此时L->next中记录的地址变为0x0,但这一操作并不影响到指针p,p中记录的内容是一份拷贝,它的值仍然是0xA。所以,不存在p==NULL,除非在执行第一条语句时L->next本身就为NULL。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询