指標陣列與陣列指標

2021-09-30 10:20:25 字數 1327 閱讀 2219

陣列指標--指向陣列的指標,是乙個指標,其指向的型別是陣列;

指標陣列--元素為指標的陣列,是乙個陣列,其中的元素為指標

1.指標陣列

陣列名本身就是乙個指標,指向陣列的首位址。注意這是宣告定長陣列時,其陣列名指向的陣列首位址是常量。而宣告陣列並使某個指標指向其值指向某個陣列的位址(不一定是首位址),指標取值可以改變。

指標陣列是多個指標組成了陣列

int *p[4]; //它是四個指標

//這四個指標組成乙個陣列

int a[4]=;

p =&a;    //進行賦值

for(int i=0;i<4;i++)

cout<<*p[i]<

2. 陣列指標:

是指向陣列的乙個指標,如int (*p)[10] 表示乙個指向10個int元素的陣列的指標。

陣列指標的動態記憶體申請:

char (*p)[10];

p=(char(*)[10])malloc(sizeof(char[x][x])*n);

#include

int main(void)

,};int (* p)[2];

char * s[2] = ;

p = a;

printf("%d, %d, %d, %d\n", (*p)[0], (*p)[1], (*(p+1))[0], (*(p+1))[1]);

printf("%s %s\n", s[0], s[1]);

return 0; }

輸出結果:

1, 2, 3, 4

hello world

3. 它們的好處:

1)指標陣列的用處

那用指標陣列的好處是什麼呢?

如果我們要定義若干字串

但是每個字串的長度不一定一樣

如果我們用陣列來儲存

那麼我們就應該以對大字串的長度為基準

這樣會造成儲存空間的浪費

我們將採用指標陣列

每個指標的位元組數是4

乘以陣列下標的最大值

就是所要的空間

當我們定義了乙個二維陣列的時候

我們用陣列指標來指向它

這樣會很方便

由前面的指標pk陣列

我們知道當要查詢陣列中元素時

指標陣列的索引方式要快捷

2)陣列指標的用處

陣列指標有乙個用處是在多維陣列中使用

會增加程式的靈活性

指標與陣列,指標陣列 陣列指標

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...