陣列首元素的首位址和陣列的首位址是不同的。前者是陣列元素的位址,而後者是陣列整體的位址。兩個東西的含義不同,但是數值上是相同的。
/*
*指標與陣列的初步結合
*/#include
int main(void)
; int *p;
//p = &a; //編譯結果warning: assignment from incompatible pointer type
//(不相容指標型別的賦值),但是執行結果是對的。
//p = &a[0];//編譯和執行都沒有問題
p = a; // 編譯和執行都沒有問題
a = p; //編譯會報錯,因為陣列名是個常量,所以不能賦值,所以陣列名不做左值
printf("*p = %d.\n", *p);
return 0;
}
p = &a[0]等同於p = a;都表示陣列首元素首位址
p = &a會報錯是因為&a是整個陣列的首位址
訪問陣列的兩種方法
int a[5]; int *p; p = a;
陣列的方式訪問:a[0] a[1] a[2] a[3] a[4]
指標的方式訪問:*p *(p+1) *(p+2) *(p+3) *(p+4)
指標與陣列,指標陣列 陣列指標
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元素的陣列。其實這兩種寫法主要是因為運算子的優先...