[英]Array shows different addresses, before and after being passed to a function by reference
我很想知道为什么相同数组(即我的数组b)的地址在传递给函数handler()之前和之后都会发生变化,如输出图片所示。 请分享您的想法,并帮助我解决这个问题。 谢谢!
#include <stdio.h>
void manipulation(int *pa,int *pb){
int i;
for(i=0;i<10;i++){
*(pb+i)=*(pa+i);
printf("%d\t %04x\n",*pb+i,&pb+i);
}
}
int main(){
int a[10],b[10];
int i;
int *point;
point = &b[0];
printf("Enter the array elements\n");
for(i=0;i<10;i++){
scanf("%d\n",&a[i]);
}
for(i=0;i<10;i++){
printf("%04x\n",&point+i);
}
manipulation(&a[0],&b[0]);
return 0;
}
因为您打印(指针的地址 )+ i:
printf("%04x\n",&point+i);
printf("%d\t %04x\n",*pb+i,&pb+i);
您要打印指针+ i:
printf("%04x\n",point+i);
printf("%d\t %04x\n",*pb+i,pb+i);
另外,您还有一个错误:
printf("%d\t %04x\n",*pb+i,pb+i);
*pb+i
被解释为(*pb) + i
,它是数组加i的第一个值,或者简称为pb[0]+i
。
您似乎得到了正确的答案,因为您的数组是1 2 3 ...
您可能想要这样:
printf("%d\t %04x\n",*(pb+i),pb+i);
或者简单地:
printf("%d\t %04x\n",pb[i],pb+i);
是的,真正的问题是将point
的地址与pb
的地址进行比较。
尝试使用point + i
(或&point[i]
)和pb + i
(或&pb[i]
)。 我相信您会得到预期的答案。
如果您感到好奇,则&point + i
是局部变量point
在内存中的point
加上i
的值。 &pb + i
是参数pb
加i
的值在内存中的位置。 它们是不同的变量,因此它们在内存中具有不同的位置。
点存储数组a的地址。 &point打印点的地址,并在整个循环中加4。 &pb也是如此。 28fee8是存储点的位置,而28fed4是存储pb的位置。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.