数组名和&数组名区别
#include <stdio.h>
int main()
{
int a[5] = {1,2,3,4,5};
int *ptr = (int *)(&a + 1);
printf("%d,%d,%d\n",*(a + 4),*(ptr - 1),*ptr); // 2 5 为什么是5
printf("数组a[4]的地址%p,(ptr-1)地址%p, ptr的地址%p",(a + 4),(ptr - 1),ptr); //
return 0;
}
a + 1 是在数组内平移一个数据类型大小
&a + 1是在数组末尾进行加一个数据类型的大小,偏移的是整个数组的大小。
这行代码:int ptr = (int )(&a + 1)。首先,取地址符 “&” 对 a 求地址,得到的是一个指向 a 的指针,它是一个数组指针,类型为 int ()[5]。接着,将这个指针加上 1,相当于将指针指向了数组 a 的末尾后的位置,即指向了一个未定义、无效的内存区域。最后,将这个指针强制转换为 int 类型的指针赋值给 ptr 变量。
然后,在这行代码中:printf(“%d,%d\n”,*(a + 1), (ptr - 1)),我们使用指针和数组下标操作来访问数组元素。(a + 1) 表示数组 a 中第二个元素的值,即 2。接着我们来看一下 *(ptr - 1) 的值。由于 ptr 指向的是 a 数组之后的一个位置,所以 ptr-1 指向数组 a 的最后一个元素。因此 *(ptr - 1) 就表示数组 a 的最后一个元素的值,即 5。
所以,这行代码的输出结果是 2,5。
#include <stdio.h>
int main(int argc, char *argv[])
{
int array[3][4] = {
{1,2,3,4},
{5,6,7,8},
{9,10,11,12}
};
int (*parray)[4] = array; //数组指针
int *ptr = (int *)(&array + 1);
int *ptr2 = (int *)(&array + 2);
printf("值%d,%d,%d\n",array[2][3],*(ptr-1),*(ptr2 - 13));
printf("array[2][3]=%p,ptr=%p,ptr2=%p\n",(*(array + 2) + 3),(ptr - 1),(ptr2 - 13));
printf("array的大小%d\n",sizeof(array));
return 0;
}
除了以下两种情况,所有的数组名都表示数组首元素的地址。
1、sizeof(数组名),计算整个数组的大小。sizeof内部单独放一个数组名,数组名表示整个数组;
2、&数组名,取出的是数组地址。&数组名,数组名表示整个数组,进行加减操作,是偏移整个数组的大小。