隨便定義乙個陣列 int arr[5];
arr現在就是陣列名, arr 代表的是該陣列整塊記憶體,即sizeof(arr) == 20 (假設sizeof(int) == 4), arr 裡的內容是該塊記憶體的首位址,即 arr == &arr[0] 。 arr可以看做是乙個常量,也就不可以使用 arr++ 之類的運算。
int *p; p = arr;
p是乙個指向int型別的指標,p = arr,就是把陣列的首位址(arr的內容就是陣列的首位址,這個前面有分析)賦給p,即 p 現在就是指向陣列的首位址,通過 p 就可以訪問整個陣列,但是 p 這裡只是是個指標變數,也就是 p 的本質沒有改變,p 不能和 arr 一樣代表整個陣列的記憶體, 所以 sizeof(p) == sizeof(int*) != sizeof(arr)。
把陣列的首位址賦給 p,但 p 的本質乙個int型別的指標變數,所以也就可以對 p 進行 ++ 之類的運算。
我們可以通過對 p ,arr 的偏移(int型別的指標 +1 或 -1, 是向上或向下偏移 sizeof(int) 個byte)來訪問陣列裡的元素, *( p + i ) ,*(arr + i),也可以通過傳統的 arr[i] 訪問陣列。
舉個例子:
int a[5] = ;
int *ptr = (int*)(&a + 1);
printf("%d, %d", *(a + 1), *(ptr - 1));
這裡的輸出的值應該是?
a 是 代表(不是指向)的是整個陣列記憶體,a 的值是該陣列記憶體的首位址, 對 a 取位址(&a),即......,所以這裡的 &a 是指向整個陣列的記憶體塊,
所以 a 的值與 &a 的值是一樣的,都是該陣列的首位址,但他們的含義是不一樣的。
這裡 &a 的每次偏移是移動整個記憶體塊的大小,這裡就是移動 sizeof(a),即40 byte,所以這裡的 &a + 1, 是指標向下移動個40byte(陣列記憶體塊的大小),&a+1的指向 是下個 sizeof(a)大小的記憶體塊。
下面是記憶體分配圖:
&a ---> ********** 假設這裡的位址值是 0x11111111 &a 和 a 的值都是 0x11111111
|| 1 ||
**********
|| 2 ||
**********
|| 3 ||
**********
|| 4 ||
********** <-----ptr-1 int型別的指標每偏移是 sizeof(int) 個 位元組
|| 5 ||
&a +1 ---> ********** <-----ptr 上面的題目中 讓 int 型別的指標 ptr 也指向了這裡
|| ? ||
**********
|| ? ||
**********
|| ? ||
**********
|| ? ||
**********
|| ? ||
&a+2 ---->**********
|| ? ||
**********
""""""
""""""
""""""
所以上面題目的輸出結果 是 :
2,5
指標與陣列,指標陣列 陣列指標
int a 10 print n a p,a p a,a print n a 1 p,a 1 p a 1,a 1 a做乙個指標,步長為4,指向乙個元素,a做乙個指標,步長為40,指向乙個維陣列 int b 3 4 print n b p,b p,b p b,b,b print n b 1 p,b 1...
指標陣列與陣列指標
1.指標陣列 指標陣列中每乙個元素都是乙個指標,也既是存放字串的首位址。所以指標陣列適合處理若干個長度不等的字串。定義的一般形式為 型別說明符 指標陣列名 陣列長度 例如 int p 3 宣告乙個陣列,指標陣列p,由3個int型別指標變數元素組成 從運算子的優先順序分析,由於 的優先順序大於 所以p...
指標陣列與陣列指標
呵呵,實在是厭倦了繞口的解釋。指標陣列,故名思義,就是指標的陣列,陣列的元素是指標 陣列指標,同樣,就是直想陣列的指標。簡單舉例說明 int p 2 首先宣告了乙個陣列,陣列的元素是int型的指標。int p 2 宣告了乙個指標,指向了乙個有兩個int元素的陣列。其實這兩種寫法主要是因為運算子的優先...