这个问题的发现是在以下的代码中发现的:

#include<stdio.h>
int main()
{
    int arr[2]={1,2};
    printf("%p",arr);
    printf("%p",&arr);
    return 0;
}

在运行之后我们发现的数组名本身的地址和数组名内部存储的地址是完全一样的,我们把数组名理解为一个const的指针(数组名只能作为右值,而不是左值),而&arr到底是什么?

我尝试在之前的代码中添加如下代码:

    printf("%p\n",arr+1);
    printf("%p\n",(&arr)+1);

在显示窗口发现,这通过指针的移位运算的表现比较奇特:

第一个是按照一个int大小来移位的

第二个是按照一个sizeof(a)来移位的

这说明 ,首先,它们都是指针,指针有两个部分,一是所存储的类型,二是指向内存的地址,上面的实际现象表示,arr本身是一个指向数组第一个元素的指针,其指针类型是int*,第二个经过取地址的运算的指针是一个类型为int[2]*的指针。

一个刚刚进入这个领域的大一新生,如有错误,多多指教。