陣列:能用索引訪問的同質元素連續集合(記憶體連續)我們可以把陣列下標用在指標上,即:
*(p + i)
等價於p[i]
指標的加減運算對於陣列同樣實用,即陣列名加減整數:
*(p + i)
等價於*(array + i)
1.array[i]
與*(array+i)
結果相同,生成的機器碼卻不同(存在異議,待修正)
2.sizeof
操作符對他們的操作不同
有**例如
int array[5] = ;
int *p = array;
則
有**如下:
int array[3][4];
int (*p)[4];
p = array;
p
與p+1
與++p
:p
是乙個int型陣列(長度4)的指標,p+1
是另乙個int型陣列(長度為4)的指標,通過乙個p
可以讀取array
的內容,++p
同理
p
讀取array[0]
:當資料型別匹配時,可以理解為*p
內的*p+0,*p+1,*p+2,*p+3
對應讀取array[0][1],array[2]...
p+1
讀取array[1]
:當數型別匹配時,同理讀取array[1]
的內容
當*p
與array
資料型別不匹配:即array[3][4]
與(*p)[5]
,因為*p
為5個int的陣列,在p
讀取array[0]
時,*p+4
佔據了array[1][0]
,在p+1
讀取array[1]
時,則從array[1][1]
開始讀取,產生其他結果,但這並不算錯誤,而是警告[warning] assignment from incompatible pointer type [-wincompatible-pointer-types]
。同理,當*p
內元素少於陣列,則提前讀取
總結(前提為資料型別匹配):
**示例:陣列指標.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元素的陣列。其實這兩種寫法主要是因為運算子的優先...