1.arr和&arr
我们学过C语言可以知道,arr并不是C语言中的关键字,只是普通的用户定义标识符。是取array(数组)前三个字符来定义数组。
不管你用arr[]={0}还是a[]={0}都是一样的。
在C语言中除了两种特殊情况下arr和&arr下指的不是首元素地址,其余情况下都是指的首元素地址。
特殊情况一:
&arr &数组名-数组名不是首元素的地址,表示的是整个数组,取出的是整个数组的地址。
特殊情况二:
当我们使用sizeof()的时候,sizeof(arr)-sizeof(数组名)–表示的是整个数组,计算的是整个数组的大小。
我们输入如下代码:
#include <stdio.h>
int main()
{
int arr[10]={0};
printf("%p\n",arr);//首元素的地址
printf("%p\n",&arr[0]);//首元素的地址
printf("%p\n",&arr);//整个数组元素的地址
}
结果如图:
欸??为什么首元素地址和整个数组的地址是一样的呢?
接下来我们就来探讨一下数组首元素地址和整个数组地址之间的关系。
2.数组首元素地址和整个数组地址
让我们来修改一下代码:
#include <stdio.h>
int main()
{
int arr[10]={0};
printf("%p\n",arr);//首元素的地址
printf("%p\n",arr+1);
printf("%p\n",&arr[0]);//首元素的地址
printf("%p\n",&arr[0]+1);
printf("%p\n",&arr);//整个数组元素的地址
printf("%p\n",&arr+1);
}
查看一下运行结果:
可以很清晰的看见arr+1和&arr[0]+1都是移动了4个字节(int型4个字节)而&arr+1我们可以看到地址相减是28,我们将十六进制的28转换成十进制得到40(首先确定一个十六进制数;然后计算出第0位以及第1位的权值;接着在第N位上,表示大小为“X * 16”的N次方)**而我们的数组大小刚好就是40!
**所以可以得知&arr取得是整个数组的地址,只不过它打印出来的值和首元素地址是一样的,但是它们所表示的意义却是大不相同的。
希望这篇文章能帮助到你~~~