很多人以為「指向陣列的指標」就是「指向指標的指標」,於是有人寫這樣的**:
int a[3][4];
int **p = a;//錯誤
這個**的錯誤之處在於a是乙個陣列,它的成員也是陣列,所以a叫做「陣列的陣列」——c++中嚴格說來沒有二維陣列。那麼,你要用乙個指標來記錄a,就要用乙個能表示「陣列的陣列」的指標,以下**是正確的:
int (*p)[4] = a;//正確
只有這樣才能保證++p使p指向a的下一對像(該對像是乙個陣列)。
順便提一句:不要寫成「int *p[4];」
來看一下指標陣列的指標怎麼用,既然都是指標也應該支援動態記憶體分配,下面的例子展示了如何對陣列的指標動態分配記憶體:
#include int main()執行結果:,,};
int (*pa)[5]=array;
int *pb[3];
int i=0;
int (*pp)[5];
pp = (int (*)[5]) malloc(sizeof(int) * 3);//注:需要這樣對指向陣列的指標分配空間
pp = array;
*pb=*pa;
*(pb+1)=*(array+1);
pb[2]=pa[2];
for(;i<3;++i)
printf("\npp pointer point to an array: \n");
for(i = 0; i < 5; i++)
printf("%d ",(*pp)[i]);
printf("\n");
return 0;
}
c++ 使用new 可以這樣寫:
#include using namespace std;執行結果:int main()
;// p = new int ((*))[3];
p = (int (*)[3])new int [3];
p = pp;
for(int i =0; i < 3; i++)
cout<
cout<
下面使用乙個函式指標陣列來展示一下指標陣列的用法:
注:這裡指標陣列主要是想說一下,函式指標陣列如何動態分配。
指標與陣列,指標陣列 陣列指標
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...
陣列 指標陣列與陣列指標
一 陣列型別 int a 10 printf a d,a 1 d n a,a 1 printf a d,a 1 d n a,a 1 輸出結果 2 陣列元素的首位址是常量,不能修改,這是為了釋放記憶體空間所必需的,否則找不到釋放記憶體空間的首位址了 3 定義乙個陣列型別 定義陣列型別的格式如下 typ...
指標陣列與陣列指標
1.指標陣列 指標陣列中每乙個元素都是乙個指標,也既是存放字串的首位址。所以指標陣列適合處理若干個長度不等的字串。定義的一般形式為 型別說明符 指標陣列名 陣列長度 例如 int p 3 宣告乙個陣列,指標陣列p,由3個int型別指標變數元素組成 從運算子的優先順序分析,由於 的優先順序大於 所以p...