推 g0010726: 陣列變數有 implicit conversion 轉換成 06/07 23:49
→ g0010726: 指向第一個element 的 pointer 06/07 23:49
→ g0010726: 於是 a 轉換成 &a[0] 恰好這個位置跟 &a 是同個地方 都 06/07 23:51
所以&a也是指陣列的開頭位置嗎?
a已經是陣列開頭的位置,&a為何不是陣列開頭位置對應的記憶體位置?
還是不懂
→ g0010726: a (int[5]) implicit converted to &a[0] (int*) 06/07 23:53
→ g0010726: &a ( int (*)[5] ) 06/07 23:53
→ Lipraxde: 為什麼你會覺得 a 本身也占有一塊記憶體位置? 06/08 00:36
我想a本身存的是陣列開頭位置,既然有存東西那就需要配置一塊記憶體位置
→ g0010726: 我猜原po可能在這裡把陣列跟pointer搞混了 一般宣告的 06/08 00:43
→ g0010726: pointer 裡面存的是指向物件的位址,但 a 裡面存的是 06/08 00:43
→ g0010726: int[5] 五個整數。主要還是前面提到的陣列implicit con 06/08 00:43
→ g0010726: version造成對於陣列跟pointer的混淆吧 06/08 00:43
→ sarafciel: 因為你這邊的a跟num代表的不是陣列的值呀 06/08 03:07
a跟num是陣列本身
→ g0010726: a這個變數指的是整個陣列 (int[5]) 不是你說的陣列開頭 06/08 11:02
→ g0010726: ,但因為存在implicit conversion, 所以當你在某些cont 06/08 11:02
→ g0010726: ext下寫a會轉成 &a[0] (int *),這個才指向陣列第一個e 06/08 11:02
→ g0010726: lement的位址, 然後這個位置址跟整個陣列的位址&a (int 06/08 11:02
→ g0010726: (*)[5]) 相同 06/08 11:02
a是陣列本身,所以&a是陣列本身的位置,其實就是陣列開頭的位置,也就是&a[0]
所以&a==&a[0],又a可隱性轉型成&a[0],所以a==&a[0]
因此&a==&a[0]==a
感謝大大的說明
→ LPH66: 那個開頭位置不會存在記憶體哪裡, 反而是直接出現在指令上 06/08 11:24
→ LPH66: 當你程式裡叫出來各種使用時編譯器會把編譯時存的對照表中 06/08 11:25
→ LPH66: 那個陣列名字對應的位址放在指令中, 這就是你 printf 裡 06/08 11:26
→ LPH66: 所看到的數字的來源 06/08 11:26
→ LPH66: 實際上存在記憶體裡的只有陣列元素值 06/08 11:26
※ 編輯: lueichun (1.164.174.184 臺灣), 06/08/2021 13:45:29