精華區beta C_and_CPP 關於我們 聯絡資訊
書上寫說 &array[i][j] 相等於 *(array + i) + j 我想了解的是 既然 array[i] 跟 array + i 一樣 (我有印出來看過) 為什麼 *array[i] 和 *(array + i) 不一樣呢?? 前者印出來就是 array[i][0] , 但後者印出來仍然長的跟原本一模一樣 又 就我的印象中 二維陣列在電腦中其實也是個一維陣列 所以我覺得 array + i 應該就是 (&array[0][0]) + i 但實際上 array[i] 卻是指向 array[i][0] 所在的位址?? ---------------- 想請了解問題的大大幫忙解答一下 謝謝~~ 我用的 compiler 是 Dev-C++ -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 218.166.31.106
khoguan:建議把你的程式碼貼上來220.130.208.168 08/12
> -------------------------------------------------------------------------- < 作者: edash (團長) 看板: C_and_CPP 標題: Re: [問題] 關於二維陣列 時間: Fri Aug 12 23:08:05 2005 ※ 引述《edash (團長)》之銘言: : 書上寫說 &array[i][j] 相等於 *(array + i) + j : 我想了解的是 : 既然 array[i] 跟 array + i 一樣 (我有印出來看過) : 為什麼 *array[i] 和 *(array + i) 不一樣呢?? : 前者印出來就是 array[i][0] , 但後者印出來仍然長的跟原本一模一樣 : 又 : 就我的印象中 : 二維陣列在電腦中其實也是個一維陣列 : 所以我覺得 array + i 應該就是 (&array[0][0]) + i : 但實際上 array[i] 卻是指向 array[i][0] 所在的位址?? : ---------------- : 想請了解問題的大大幫忙解答一下 : 謝謝~~ : 我用的 compiler 是 Dev-C++ 這是我的程式碼: #include<iostream> using namespace std; int main(){ int a[3][4]; cout << *(a[1]) <<" "<< a[1][0] <<endl; cout << a+1 <<" "<< a[1] <<endl; cout << *(a+1) <<" "<< a[1][0] <<endl; system("PAUSE"); } 以下是輸出: 2009109320 2009109320 0x22ff50 0x22ff50 0x22ff50 2009109320 請按任意鍵繼續 . . . ---------------- 可以看到 a+1 和 *(a+1) 長的一樣,這是我所不懂的 還有 a+1 和 a[1] 長的一樣,但 *(a+1) 卻和 *(a[1]) 不同 我想這些大概就是我不了解的地方了 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 218.166.31.106
khoguan:有請大大們幫忙解答 ^_^220.130.208.168 08/13
> -------------------------------------------------------------------------- < 作者: LPH66 (運命のルーレット廻して) 看板: C_and_CPP 標題: Re: [問題] 關於二維陣列 時間: Sat Aug 13 13:38:44 2005 ※ 引述《edash (團長)》之銘言: : 這是我的程式碼: : #include<iostream> : using namespace std; : int main(){ : int a[3][4]; : cout << *(a[1]) <<" "<< a[1][0] <<endl; : cout << a+1 <<" "<< a[1] <<endl; : cout << *(a+1) <<" "<< a[1][0] <<endl; : system("PAUSE"); : } : 以下是輸出: : 2009109320 2009109320 : 0x22ff50 0x22ff50 : 0x22ff50 2009109320 : 請按任意鍵繼續 . . . : ---------------- : 可以看到 a+1 和 *(a+1) 長的一樣,這是我所不懂的 : 還有 a+1 和 a[1] 長的一樣,但 *(a+1) 卻和 *(a[1]) 不同 : 我想這些大概就是我不了解的地方了 a是一個int ** 所以a+1也是int ** 故*(a+1)是一個int * 對cout來說 它們兩個都是指標 自然用指標的方式輸出 所以這表示它們指的位址相同 而*(a+1)表示a[1] 那是二維陣列第二行的開頭指標 a+1表示&a[1] 表示a[1]所在的位置 而第二行的開頭指標自然就是a[1]的位置 所以兩個位址是相同的 但是它們表示不同的東西 又 *(a[1]) 相當於*(a[1]+0) 也就是a[1][0] 自然和*(a+1)不一樣了 *(a[1]) 是一個int 表示a[1]指到的地方的值 就是a[1][0]的值 -- "LPH" is for "Let Program Heal us".... -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 219.84.44.21 > -------------------------------------------------------------------------- < 作者: khoguan (Khoguan Phuann) 看板: C_and_CPP 標題: Re: [問題] 關於二維陣列 時間: Mon Aug 15 05:50:53 2005 ※ 引述《LPH66 (運命のルーレット廻して)》之銘言: : ※ 引述《edash (團長)》之銘言: : : 這是我的程式碼: : : #include<iostream> : : using namespace std; : : int main(){ : : int a[3][4]; : : cout << *(a[1]) <<" "<< a[1][0] <<endl; : : cout << a+1 <<" "<< a[1] <<endl; : : cout << *(a+1) <<" "<< a[1][0] <<endl; : : system("PAUSE"); : : } : : 以下是輸出: : : 2009109320 2009109320 : : 0x22ff50 0x22ff50 : : 0x22ff50 2009109320 : : 請按任意鍵繼續 . . . : : ---------------- : : 可以看到 a+1 和 *(a+1) 長的一樣,這是我所不懂的 : : 還有 a+1 和 a[1] 長的一樣,但 *(a+1) 卻和 *(a[1]) 不同 : : 我想這些大概就是我不了解的地方了 : a是一個int ** 所以a+1也是int ** 將 a 解釋為 int** 固然可以順利的解釋原po的問題。 但是嚴格來說,並不是這樣,像是: int foo(int** arr) { return arr[1][2]; } int main() { int arr[2][3] = { {0,1,2}, {3,4,5} }; foo(arr); return 0; } 在 C++ 是編譯不過的。C 也會警告指標的型別不相容。 arr 本身的型別是 int[2][3],在許多情形下使用到 arr 時, arr 會 decay 成為 int (*)[3],但 int (*)[3] 並不會進一步 又 decay 成為 int** : 故*(a+1)是一個int * : 對cout來說 它們兩個都是指標 自然用指標的方式輸出 所以這表示它們指的位址相同 : 而*(a+1)表示a[1] 那是二維陣列第二行的開頭指標 : a+1表示&a[1] 表示a[1]所在的位置 而第二行的開頭指標自然就是a[1]的位置 : 所以兩個位址是相同的 但是它們表示不同的東西 : 又 *(a[1]) 相當於*(a[1]+0) 也就是a[1][0] 自然和*(a+1)不一樣了 : *(a[1]) 是一個int 表示a[1]指到的地方的值 就是a[1][0]的值 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 220.130.208.168
edash:所以說這個問題還未有真正答案出現??? 218.166.37.162 08/15
> -------------------------------------------------------------------------- < 作者: khoguan (Khoguan Phuann) 看板: C_and_CPP 標題: Re: [問題] 關於二維陣列 時間: Wed Aug 17 00:27:03 2005 ※ 引述《edash (團長)》之銘言: : ※ 引述《edash (團長)》之銘言: : : 書上寫說 &array[i][j] 相等於 *(array + i) + j : : 我想了解的是 : : 既然 array[i] 跟 array + i 一樣 (我有印出來看過) : : 為什麼 *array[i] 和 *(array + i) 不一樣呢?? : : 前者印出來就是 array[i][0] , 但後者印出來仍然長的跟原本一模一樣 : : 又 : : 就我的印象中 : : 二維陣列在電腦中其實也是個一維陣列 是的。例如 char a[3][2]; 是 3 個元素的一維陣列,它的 元素的 type 是 char[2] 也就是兩個 char 元素的陣列。 : : 所以我覺得 array + i 應該就是 (&array[0][0]) + i ^ ^ 不是的。請再弄清楚 (pointer + 整數) 的意義。 那個整數 i 並不是 i 個 1 byte , 而是以 pointer 所指的 元素的大小為單位。前面那個 i 和後面那個 i 的單位是不 一樣的。以 char a[3][2] 為例, a + 1; a 在這裡是指向 a陣列的第 0 個元素,該元素是 char[2],2 bytes 大。 a + 1 以後,就要加 1*2 bytes 指向第 1 個 char[2] 元素。 (&a[0][0]) + 1; a[0][0] 就只是個 char, 前面加上 &, 取它的位址, 其 type 就是 char*, 也就是指向 char (1 byte 大) 的指標,它 + 1 就是加 1*1 bytes, 指向第 0 個 char[2] 元素裡面的第 1 個元素。 : : 但實際上 array[i] 卻是指向 array[i][0] 所在的位址?? : : ---------------- : : 想請了解問題的大大幫忙解答一下 : : 謝謝~~ : : 我用的 compiler 是 Dev-C++ : 這是我的程式碼: : #include<iostream> : using namespace std; : int main(){ : int a[3][4]; : cout << *(a[1]) <<" "<< a[1][0] <<endl; : cout << a+1 <<" "<< a[1] <<endl; : cout << *(a+1) <<" "<< a[1][0] <<endl; : system("PAUSE"); : } : 以下是輸出: : 2009109320 2009109320 : 0x22ff50 0x22ff50 : 0x22ff50 2009109320 : 請按任意鍵繼續 . . . : ---------------- : 可以看到 a+1 和 *(a+1) 長的一樣,這是我所不懂的 a 本質上是陣列,type 為 int[3][4]。當你使用 a 時,大部份的 情形下,它都會變為指向第 0 個元素 int[4] 的指標,所以 a 的 type 會變成 int (*)[4] a+1 的意義如前述是指向第 1 個(不是第 0 個) int[4] 元素的指標, 其 type 是 int (*)[4] 將它的前面加上 *, 變成 *(a+1) 就是 dereference 它,結果就是 int[4]這個元素本身,這個元素本身的 type 剛好也是個陣列,type 為陣列的東西,在大部份的情形下都會變成指向陣列第 0 個元素的指標, 就是 int*, 和 a+1 這個指標都指向同一點,所以位址值一樣。但其實 type 不一樣。 : 還有 a+1 和 a[1] 長的一樣,但 *(a+1) 卻和 *(a[1]) 不同 a[1] 就是第 1 個 int[4] 元素本身, cout << 時,變成指標, type 為 int*,輸出的是位址值。 *(a[1]) 是 dereference 這個 int*,就是提取它所指的整數值了。 當然 cout << 就印出該整數值。 : 我想這些大概就是我不了解的地方了 這個問題實在很難解釋。 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 220.130.208.168
edash:先感謝一下大大,不過我最近真的看到快頭暈了說 220.136.17.114 08/18
edash:我想說過幾天再來吸收一下,到時有疑問再來請教 220.136.17.114 08/18
edash:謝謝 220.136.17.114 08/18
edash:乍看之下有點了解卻又不太了解 220.136.16.187 08/21
edash:我相信大大已點出了問題的癥結 220.136.16.187 08/21
edash:相信我快要能完全吸收,謝謝 220.136.16.187 08/21