在 c/c++ 中,陣列與指標是既相互關聯又有區別的兩個概念。當我們宣告乙個陣列時,其陣列的名字也是乙個指標,該指標指向陣列的第乙個元素。
陣列名的意義:
sizeof(陣列名),這裡的陣列名表示整個陣列,計算的是整個陣列的大小。
&陣列名,這裡的陣列名表示整個陣列,取出的是整個陣列的位址。
除此之外所有的陣列名都表示首元素的位址。
arr
和&arr
分別是啥?
int
main()
;printf
("arr = %p\n"
, arr)
;// arr = 0x7ffee27d8460
printf
("&arr= %p\n"
,&arr)
;// &arr= 0x7ffee27d8460
printf
("arr+1 = %p\n"
, arr+1)
;// arr+1 = 0x7ffee27d8464
printf
("&arr+1= %p\n"
,&arr+1)
;// &arr+1= 0x7ffee27d8488
return0;
}
總結:陣列指標與指標陣列區別:int (*p)[10]
-----定義陣列指標
這裡有個有意思的話題值得**一下:平時我們定義指標不都是在指標型別後面加上指標變數名麼?這個指標 p 的定義怎麼不是按照這個語法來定義的呢?也許我們應該這樣來定義p:
int(*
)[10] p;
int (*)[10]是指標型別,p 是指標變數。其實陣列指標的原型確實就是這樣子的,只不過為了方便與好看把指標變數p 前移了而已。
定義:
int
(*p)
[n];
//本質是乙個指標
()優先順序高,首先說明p是乙個指標,指向乙個整型的一維陣列,這個一維陣列的長度是n,也可以說是p的步長。也就是說執行p+1時,p要跨過n個整型資料的長度。
如要將二維陣列賦給一指標,應這樣賦值:
int a[3]
[4];
int(
*p)[4]
;//該語句是定義乙個陣列指標,指向含4個元素的一維陣列。
p=a;
//將該二維陣列的首位址賦給p,也就是a[0]或&a[0][0]
p++;//該語句執行過後,也就是p=p+1;p跨過行a[0]指向了行a[1]
所以陣列指標也稱指向一維陣列的指標,亦稱行指標。
定義:
int
*p[n]
;//本質是乙個陣列
優先順序高,先與p結合成為乙個陣列,再由int*說明這是乙個整型指標陣列,它有n個指標型別的陣列元素。
但可以這樣 *p=a; 這裡 *p表示指標陣列第乙個元素的值,a的首位址的值。
比如:
char arr[4]
=;//這裡的arr是乙個指標陣列,它裡面有兩個元素,每個元素都是乙個指標型別。
如要將二維陣列賦給一指標陣列:
int
*p[3];
int a[3]
[4];
for(i=
0;i<
3;i++
)//這裡int *p[3] 表示乙個一維陣列內存放著三個指標變數,分別是p[0]、p[1]、p[2]
所以要分別賦值。
陣列指標只是乙個指標變數,似乎是c語言裡專門用來指向二維陣列的,它占有記憶體中乙個指標的儲存空間。
指標陣列是多個指標變數,以陣列形式存在記憶體當中,占有多個指標的儲存空間。
還需要說明的一點就是,同時用來指向二維陣列時,其引用和用陣列名引用都是一樣的。
比如要表示陣列中i行j列乙個元素:
*(p[i]+j)、 *( *(p+i)+j)、 *(p+i))[j]、p[i][j]
優先順序:()>>*
64位系統中,**a[3][4],(**a)[3][4], *(*a)[3][4], *(*a[3])[4]等變數占用的記憶體空間為()?
C 指標陣列與陣列指標詳解
首先先定義乙個指標陣列,既然是陣列,名字就叫arr char arr 4 arr就是我定義的乙個指標陣列,它有四個元素,每個元素是乙個char 型別的指標,這些指標存放著其對應字串的首位址。即 char arr 4 當乙個變數出現左右都出現乙個運算子時,沒有記住運算子優先順序的人就會糾結arr變數到...
指標陣列與陣列指標詳解
首先先定義乙個指標陣列,既然是陣列,名字就叫arr char arr 4 arr就是我定義的乙個指標陣列,它有四個元素,每個元素是乙個char 型別的指標,這些指標存放著其對應字串的首位址。當乙個變數出現左右都出現乙個運算子時,沒有記住運算子優先順序的人就會糾結arr變數到底跟哪乙個運算子先結合。如...
指標陣列與陣列指標詳解
指標的陣列 首先這個變數是乙個陣列,其次,指標 修飾這個陣列,意思是說 這個陣列的所有元素都是指標型別 在32位系統中,指標佔四個位元組 陣列指標 陣列指標可以說成是 陣列的指標 首先這個變數是乙個指標,其次,陣列 修飾這個指標,意思是說這個指標存放著乙個陣列的首位址,或者說這個指標指向乙個陣列的首...