temp2
,temp1
是一些结构x的指针:
struct FunkyStruct x; struct FunkyStruct *temp1 = &x, *temp2 = &x;
现在,在执行以下行之后:
temp2=temp1; temp1=temp1->nxt;
...将temp2
与temp1
仍指向同一个内存位置?如果没有,请解释为什么它们会有所不同.
最初,temp1
并且temp2
都包含的内存地址x
.
temp2 = temp1
表示"赋值temp1
给temp2
".由于它们具有相同的值,因此该命令不执行任何操作.
表达式temp1->next
意味着"查看temp1
指向的数据结构内部,并返回字段的值next
".所以temp1 = temp1->next
赋予temp1->next
to 的值temp1
.(当然,查找发生在赋值之前.) temp1
现在将包含该next
字段恰好包含的任何值.它可能与旧值相同,也可能不同.
这听起来像一个基于java背景的问题?
dysfunctor给出的答案是好的.
要认识到的重要一点是,在C中,指定指针与指定整数没有什么不同.
请考虑对原始代码进行以下修改:
int temp1 = 1; int temp2; temp2=temp1; temp1=temp1 + 1;
在temp1的末尾是2,temp2是1.
这与在java中分配(非原始)对象不同,其中赋值实际上分配了对象的引用而不是值.