一、陣列名的含義
在c/c++中,陣列名就是位址,即陣列在記憶體中的位置,它表示第乙個元素的位址(首位址)
int arr[4]=;
int* p=arr;//arr本身的型別就是int*
相當於int *p=&arr[0];//第一元素的位址
二、指標的加減法
指標加法:後移n個元素
指標減法:前移n個元素
三、用p指向陣列中arr的任意乙個元素
例如:指向arr[3]
第一種方法:p=arr+3;
第二種方法:p=&arr[3];
四、給陣列元素賦值
第一種方法:arr[3]=10;
第二種方法:*(arr+3)=10;
或p=arr+3; *p=10;
五、指標與陣列的關係
把p可以當成陣列使用
int* p = &arr[1];
p[0] = 0xaa; // p[0]: 自p開始的第0號元素, 即arr[1]
p[1] = 0xbb; // p[1]: 即arr[2]
------------------------
int a = 10;
int* p = &a;
p[0] = 11; // 長度為1的陣列
六、陣列的遍歷
第一種方法:
int arr[4];
for(int i=0; i<4; i++)
第二種方法:
int arr[4];
for(int* p= arr; p
七、越界訪問
int arr[4] = ;
arr[4] = 10; //執行時錯誤!
注:錯誤分為編譯錯誤和執行錯誤。編譯錯誤由編譯檢查,屬於語法上的錯誤。執行錯誤只有在執行時才出錯,一般會導致程式崩潰。
使用指標訪問陣列元素時,也不能越界。
int* p = arr;
* (p + 4) = 10; // 執行時錯誤!// 嚴重的隱惑
八、直接把數組成看一塊記憶體就可以了。陣列名就是這塊記憶體的位址。 然後通過指標來訪問它就可以了。
九、小結
陣列和指標可以靈活的相互轉換
指標與陣列,指標陣列 陣列指標
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元素的陣列。其實這兩種寫法主要是因為運算子的優先...