深入理解陣列指標與指標陣列的區別

2022-10-04 05:09:07 字數 1091 閱讀 4066

陣列指標與指標陣列的區別在於:陣列指標p是乙個指標,而指標陣列p是乙個存放n個指標變數的陣列。

一、陣列指標

int (*p)[n]

重點:()優先順序高(、()的優先順序是一樣的,但它們的方向是從左至右的,所以先執行括號裡的*p),首先說明p是乙個指標,指向乙個整型的一維陣列,這個一維陣列的長度是n,也可以說是p的步長。也就是說執行p+1時,p要跨過n個整型資料的長度(n*sizeof(int))。

如要將二維陣列賦給一指標,應這樣賦值:

int a[3][4];

int (*p)[4]; //該語句是定義乙個陣列指標,指向含4個元素的一維陣列。

p = a;        //將該二維陣列的首位址賦給pswxl**e,也就是a[0]或&a[0][0]

p++;      //<=>a[1]<=>p[1]

同時用來指向二維陣列時,其引用和用陣列名引用都是一樣的即a<=>p。比如要表示陣列中i行j列乙個元素a[i][j]:

p[i][j]<=>a[i][j] <=>*(p[i]+j)<=>*(a[i]+j) <=> *(*(p+i)+j)*(*(a+i)+j) <=>  (*(p+i))[j]<=>(*(a+i))[j]

二、指標陣列

int *p[n]

重點:優先順序高,先與p結合成swxl**e為乙個陣列,再由int*說明這是乙個整型指標陣列,它有n個指標型別的陣列元素:即它就是乙個存放了n個指標的陣列。

這樣賦值也是錯誤的:p=a;因為p是個右值,p的值只存在p[0]、p[1]、p[2]...p[n-1],而且它們分別是指標變數可以用來存放變數位址。swxl**e但可以這樣*p=a; 這裡*p表示指標陣列www.cppcns.com第乙個元素的值,a的首位址的值。

如要將二維陣列賦給一指標陣列:

int *p[3];

int a[3][4];

for(i = 0; i < 3; i++)

p[i] = a[i];

這裡int *p[3] 表示乙個一維陣列內存放著三個指標變數,分別是p[0]、p[1]、p[2],預設情況下這三個指標變數都指向null的,所以要分別賦值。

本文標題: 深入理解陣列指標與指標陣列的區別

本文位址:

深入理解指標 陣列

指標的本質是乙個變數,也需要占用一定的空間一般為四個位元組不論其指向的型別。指標用來儲存記憶體位址的值。通過指標我們能做到不通過變數來改變變數的值。號的意義 在指標宣告時,代表宣告的變數為指標變數。int i 10 int p i 在指標使用時,表示取指標所指向的位址中的值。p 12 另外指標宣告時...

理解陣列與指標

int a 10 a本身是陣列名也是指向第乙個陣列元素的指標。a 1是指向第二個陣列元素的指標。也就是說a這個指標的值就是 a 0 a這個指標和a都指向同乙個記憶體位址,但是 a這個指標的意義卻是指向整個陣列,a 1指向a這個陣列結束後的位置。宣告乙個指標指向來指向這個陣列可以這樣宣告 int p ...

深入理解陣列 下

本文以實踐為主,舉幾個基本的常用的例子。所以原始碼已上傳至github 鏈結 public int find int index 複製 public boolean insert int index,int value for int i count 1 i index i array index ...