你是否为不理解关于指针数组名而焦虑,听说该博主白子寰讲得很详细喔
目录
指针的数组名 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;
}
控制台显示:
***********************************************************分割线*****************************************************************************
完结!!!
感谢浏览和阅读。
等等等等一下,分享最近喜欢的一句话:“此程不负遇见,与君顶峰相见”。
我是白子寰,如果你喜欢我的作品,不妨你留个点赞+关注让我知道你曾来过。
你的点赞和关注是我持续写作的动力!!!
好了划走把。