今天無意中看到一道題目,考察的是陣列與指標,如下
int a[5] = ;
int *ptr1 = (int *)(a + 1);
int *ptr2 = (int *)(&a + 1);
printf("%d %d\n" , *ptr1, *(ptr2-1));
初一看,我想的答案是2,1,因為a是陣列名稱,也就是陣列的首位址,a+1指向的就是陣列的第二個元素了,也就是2,所以列印的是2,&a+1也是這樣理解的,先+1再-1,那應該輸出的是陣列的第乙個元素了,但是上機執行,輸出的是2,5,感覺很不解,於是用了下面這個語句去查各個元素分配的位址
printf("%p %p %p %p %p %p %p %p %p\n", a, &a, &a[0], &a[1], &a[2], &a[3], &a[4], ptr1, ptr2);
列印出來的結果是0022fe84 0022fe84 0022fe84 0022fe88 0022fe8c 0022fe90 0022fe94 0022fe88 0022fe98
從這個結果可以看出a,&a[0],&a這三者在數值上是一樣的,都表示了數字a的首位址,但是a+1和&a+1的結果卻是完全不同的,後來查了資料,原來a的資料型別是int *,而&a的資料型別是int (*)[5],於是sizeof(&a)=5*sizeof(int)=20,所以&a+1實際上跳過了整塊的a所分配的記憶體位址,也就是越界了,ptr2-1將指標拉回到陣列a所在的位址區域,指向了a[4],所以會輸出5,至此這道題我算是理解了。從這裡看出,c語言中的指標真的是很靈活,需要用心去體會了。
指標與陣列,指標陣列 陣列指標
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元素的陣列。其實這兩種寫法主要是因為運算子的優先...