1.指標運算元組快於下標運算元組
2.陣列的空間分配.如int a[10];——會在空間分配出40個相鄰的記憶體單元來(10*4)。
注意事項:
a、陣列不可以進行++ar運算;也不可以ar=null;//陣列名退化成指標後,不可以++ar和賦值操作,因為退化後ar為常量值,代表首元素的位址
3.指標運算元組
int *pa;
pa = &a[0];
4.指標移動
int *pa;
int a[10];
pa = &a[0];
pa+1 等於是指向第5個記憶體單元——a[1]的第乙個記憶體單元。
注意事項:
&p是指標位址,&p+1會根據指標指定的型別int移動4個記憶體單元,1的大小是取決於pa的型別int的,指標型別決定指標跨記憶體單元的步長。
5.規則:
>> &ar[i]和ar+i含義相同,相互使用。ar+i是ar之後第i個元素位址。
>> 陣列名代表陣列第乙個元素的位址。
6.指標相減:
int ar[10]=;
int *p1=&ar[0];
int *p2=&ar[4];
int len=p2-p1;//兩個指標相減,表示倆個指標之間隔了多少個元素;
指標相減特點:
(1)、兩個指標間的型別相同;(2)、算頭不算尾,即元素個數為p2-p1+1;(3)、(p2-p1)/2+p1;//求p1和p2中間的指標;
注意:兩個指標之間只能進行相減,不能進行相加。
指標與陣列,指標陣列 陣列指標
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元素的陣列。其實這兩種寫法主要是因為運算子的優先...