[问题] 阵列名称所存的值与其所在的位置,两者的值为何相同

楼主: lueichun (no anonymous)   2021-06-07 21:31:43
问题(Question):
假设有一个阵列,叫做int a[5];
则a==&a==&a[0],a==&a[0]可以理解,但为何a==&a?
a的值是阵列开头的位置(假设是1000),且a本身也占有内存位置(假设是2000),
那&a不是应该是那个内存空间位置(2000)吗?
所以应该是两个不同的位置,但为何程式跑出来a==&a:
int main (int argc,char *argv[]){
int a[5];
printf("%p %p %p",a,&a[0],&a);
//结果为000000000062FE00 000000000062FE00 000000000062FE00
return 0;
}
二维阵列也是一样的状况,若有一阵列叫做num[3][4],则num==&num
num[0]==&num[0] num[1]==&num[1]......
我看书上都没有解释的很清楚,希望有人可以解惑,拜托了。
作者: LPH66 (-6.2598534e+18f)   2021-06-07 21:46:00
作者: g0010726 (Kevin)   2021-06-07 23:49:00
阵列变量有 implicit conversion 转换成指向第一个element 的 pointer于是 a 转换成 &a[0] 恰好这个位置跟 &a 是同个地方 都a (int[5]) implicit converted to &a[0] (int*)&a ( int (*)[5] )
作者: Lipraxde (Lipraxde)   2021-06-08 00:36:00
为什么你会觉得 a 本身也占有一块内存位置?
作者: g0010726 (Kevin)   2021-06-08 00:43:00
我猜原po可能在这里把阵列跟pointer搞混了 一般宣告的pointer 里面存的是指向物件的位址,但 a 里面存的是int[5] 五个整数。主要还是前面提到的阵列implicit conversion造成对于阵列跟pointer的混淆吧
作者: sarafciel (Cattuz)   2021-06-08 03:07:00
因为你这边的a跟num代表的不是阵列的值呀
作者: g0010726 (Kevin)   2021-06-08 11:02:00
a这个变量指的是整个阵列 (int[5]) 不是你说的阵列开头,但因为存在implicit conversion, 所以当你在某些context下写a会转成 &a[0] (int *),这个才指向阵列第一个element的位址, 然后这个位置址跟整个阵列的位址&a (int(*)[5]) 相同https://imgur.com/2w7VL9S
作者: LPH66 (-6.2598534e+18f)   2021-06-08 11:24:00
“有存东西”是个大误解, 看我这篇后续回文 #1EA_5rFL那个开头位置不会存在内存哪里, 反而是直接出现在指令上当你程式里叫出来各种使用时编译器会把编译时存的对照表中那个阵列名字对应的位址放在指令中, 这就是你 printf 里所看到的数字的来源实际上存在内存里的只有阵列元素值

Links booklink

Contact Us: admin [ a t ] ucptt.com