指针的数组名 VS &数组名
我们先来看下段简单的代码
①段代码
int main() { int arr[10] = { 0 }; printf("%p\n", &arr); printf("%p\n", &arr[0]); printf("%p\n", arr); return 0; }
结果会输出什么呢?
关于打印地址的 &数组名,&数组首元素 和 数组名 有什么区别?
控制台输出显示:
我们发现,三者打印出来的地址完全一样;
那么,我们可不可以认为:数组名是数组首元素的地址?
来,我们继续来看下段长的代码:
②段代码
注:%p是用来打印地址的
int main() { int arr[10] = { 0 }; printf("sizeof(arr) = %d\n", sizeof(arr)); printf("\n"); printf("&arr[0] = %p\n", &arr[0]); printf("&arr[0]+1 = %p\n", &arr[0]+1); printf("\n"); printf("arr = %p\n", arr); printf("arr+1 = %p\n", arr+1); printf("\n"); printf("&arr = %p\n", &arr); printf("&arr+1 = %p\n", &arr+1); return 0; }
来思考一下,这段代码的结果会输出什么?
分段代码解释:
下面👇是X86环境下控制台输出 :
我们可以看出 &arr[0] 和&arr[0]+1 , arr 和 arr+1 都相差4个字节(byte)
因为&arr 和 arr 都是首元素的地址,+1就是跳过一个元素,也就是4个字节(byte)
但 &arr 和 &arr+1 相差40个字节(byte)
因为&arr是数组的地址,+1操作是跳过整个数组的
小结
从上面也可以得出,关于 数组名 和 &数组名 的理解有两个例外 :
指针访问数组
在学 指针变量的意义我们有涉及到
这里就不过多的赘述,如果还不理解,点击👆上面蓝色字体;
但不同的是在控制台输入和输出,输入和输出我分别列出了三种方式
看下段代码:
int main() { int a[10] = { 0 }; int sz = sizeof(a) / sizeof(a[0]); int* p = a; int i = 0; //输入 for (i = 0; i < sz; i++) { /*方式一*/ //scanf("%d", &a[i]); /*方式二*/ //scanf("%d", (p+i)); /*方式三*/ scanf("%d", (a + i)); } //输出 for (i = 0; i < sz; i++) { /*方式一*/ //printf("%d ", a[i]); /*方式二*/ //printf("%d ", *(a + i)); /*方式三*/ printf("%d ", *(p + i)); } printf("\n"); return 0; }
控制台显示: