指標陣列與陣列指標的區別

2022-08-16 02:48:05 字數 974 閱讀 5417

陣列指標(也稱行指標)

定義 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+1是錯誤的,這樣賦值也是錯誤的:p=a;因為p是個不可知的表示,只存在p[0]、p[1]、p[2]...

p[n- 1],而且它們分別是指標變數可以用來存放變數位址。但可以這樣 *p=a; 這裡*p表示指標陣列第乙個元素的值,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]

所以要分別賦值。

這樣兩者的區別就豁然開朗了,陣列指標只是乙個指標變數,似乎是c語言裡專門用來指向二維陣列的,它占有記憶體中乙個指標的儲存空間。指標陣列是多個指標變數,以陣列形式存在記憶體當中,占有多個指標的儲存空間。

還需要說明的一點就是,同時用來指向二維陣列時,其引用和用陣列名引用都是一樣的。

比如要表示陣列中i行j列乙個元素:

*(p[i]+j)、*(*(p+i)+j)、(*(p+i))[j]、p[i][j]

指標和陣列習題

一 1 陣列可以在定義時整體賦初值,但不能在賦值語句中整體賦值 2.取陣列a的第5個元素的位址,正確的寫法是 a a 4 b a 4 c a 4 d a 4 3.程式段輸出結果是 int main 12345 b 12345 c 12345d 12345 12345.1234612345.12345...

字元陣列,字元指標,sizeof,strlen總結

cpp 字元陣列,字元指標,sizeof,strlen總結 對於字元陣列與字元指標 1.以字串形式出現的,編譯器都會為該字串自動新增乙個0作為結束符,如在 中寫 abc 那麼編譯器幫你儲存的是 abc 0 2.字串直接量作為字元指標的初始值 hello 是乙個字串直接量,編譯器將其作為const c...

實驗 陣列 函式和指標

1.程式設計實現 定義乙個長度為8的整型陣列並初始化,從鍵盤輸入乙個要查詢的數,查詢並輸出陣列中的 第乙個該數的位置序號 從0開始 如沒有該數則輸出 陣列中無此數!2.定義乙個求一維陣列最小值的函式,函式形式為 int min int array,int n 在主函式中定義乙個長度為10的陣列,並用...