holdtom
A和&a的价值是一样的,怎么回事?它们的价值相同,但类型不同。数组对象在元素之间没有填充(前后),因此数组的地址和数组的第一个元素的地址是相同的。即:(void *) a == (void *) &a它到底做了什么int(*p)[3];定义指向数组的指针,我知道,但是,指向数组的指针与指向数组的第一个元素的指针和数组的名称有什么不同呢?这是两种不同的指针类型。例如,指针算法:a + 1 /* address of the second element of the array */&a + 1 /* address one past the last element of the array */编辑:由于普遍的需求,我在下面添加了一些关于数组转换的信息。除三个例外情况外,在表达式中,类型为T被转换为类型指针的值。T指向数组的第一个元素。如果对象是sizeof或&如果对象是字符串,则初始化数组。例如,这一声明:printf("a:%d\t&a:%d\n", a, &a);实际上相当于:printf("a:%d\t&a:%d\n", &a[0], &a);还请注意d转换说明符只能用于打印有符号整数;要打印指针值,必须使用p说明符(参数必须是void *)。因此,要正确地做事情,请使用:printf("a:%p\t&a:%p\n", (void *) a, (void *) &a);分别:printf("a:%p\t&a:%p\n", (void *) &a[0], (void *) &a);