致讀者
陣列名和指標有何關聯?訪問陣列元素的方括號[ ]和指標有何關聯?請一點點的往下閱讀——
指向陣列元素的指標
指向陣列元素的指標,也就是陣列元素的地址,它們展現出怎樣的特點,或者說,規律呢?
以下面這段代碼為例:
int main()
{
int arr[10];
int i = 0;
int sz = sizeof(arr) / sizeof(arr[0]);
for(i=0;i<sz;i++)
printf("&arr[%d]=%p\n",i, &arr[i]);
return 0;
}
輸出結果為:

我們知道,地址在記憶體以十六進制數存放
首元素地址: 012FFA60
與第二個元素的地址:012FFA64 相差了4
第二與第三個的地址:012FFA68 相差了4
由此可見,指向陣列元素的指標是連續的,且間隔1個元素的大小(這里是整型陣列,元素大小為4位元組);
陣列名和陣列地址和元素地址
看到這個標題,你是否想起了曾經被支配的恐懼?別怕,讓我再捋一遍——
以代碼入手:
int main()
{
int arr[10];
printf("%p\n", arr);
printf("%p\n", &arr);
return 0;
}
讓我們看一下輸出結果:

陣列名arr居然和&arr的值一毛一樣???是否可以認為,它們是一個東西?
答案是:NO!!!
在之前的博客我介紹過一次:陣列名在多數情況下,表示的是首元素的地址,我們來看:

但是兩種情況除外,我們首先介紹第一種情況,也就是sizeof(arr),在這里,arr代表的是整個陣列,所以sizeof(arr)計算的就是整個陣列的大小,我們來看:

第二種情況,牽扯到&arr和arr的關系:
我們剛才也看到了,&arr和arr以%p格式化列印的結果是一樣的,但這僅僅意味著它們在數值上相同,區別在哪里?看下面這段代碼:
int main()
{
int arr[10];
printf("%p\n", arr+1);
printf("%p\n", &arr+1);
return 0;
}
輸出結果:

what?同樣是加一,arr+1在原來首元素的基礎上增加了4,但是&arr+1居然增加了40!
(不知道為什么是40的是十六進制還沒弄清楚哦,可以看看我前面《詳解資料存盤(上)——進制》這篇文章)
這個結果就牽扯到&arr和arr的區別了:
arr是陣列名,一般情況下陣列名等價于首元素地址,這里元素型別為int,所以元素指標型別為int*,int*的步長為4,也就是說,它加1,相當于訪問越過4個位元組后的地址,4個位元組也就是一個元素的大小,那么我們也可以理解為,arr+1后訪問第二個元素,所以arr+1在arr的數值基礎上加了4,
但是&arr拿到的是整個陣列的地址,當它加一,相當于越過整個陣列后訪問,也就是,訪問陣列最后一個元素之后的那個地址,所以他在arr的數值基礎上,增加了40,也就是整個陣列的大小!!!
講到這里先小小總結一下:
1、陣列名是首元素的地址,即陳述句arr==&arr[0]成立(有兩個例外)
①sizeof(arr)中arr表示整個陣列,所以sizeof(arr)計算的是整個陣列的大小,單位是位元組;
②&arr中arr代表整個陣列,&arr取出的是整個陣列的地址;
如:printf("%p “, &arr+1)列印陣列最后一個元素的后一個地址;
而 printf(”%p ", arr+1)列印的是第二個元素的地址;
2、int* arr和int arr[]都表示arr是一個指向int的指標,但int arr[]只能用于宣告形式引數,如int fun ( int arr [ ] );
3、陣列中元素地址+1表示下一個元素的地址;
如:printf("%p “, &arr[1]);
和printf(”%p\n", &arr[0]+1);
輸出的結果相同,都是第二個元素的地址
利用指標訪問陣列元素
參照以下代碼:
int main()
{
int arr[5] = { 1,2,3,4,5 };
int i = 0;
for (i = 0; i < 5; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
這里我們通過arr[ i ]的形式訪問陣列的第i-1個元素;
同樣,我們還可以用第二種方式:
int main()
{
int arr[5] = { 1,2,3,4,5 };
int i = 0;
for (i = 0; i < 5; i++)
{
printf("%d ", *(arr + i));
}
return 0;
}
通過上面的學習,我們知道,arr+i就是陣列首元素后的第i個元素的地址,通過對他的解參考,我們獲得了陣列首元素后的第i個元素,也就是第i+1個元素;
綜上我們知道,arr[ i ]等價于* (arr + i) ,也就是arr[ i ]==* (arr + i)成立,這一點對于利用指標訪問二維陣列有大作用!(下一篇我們繼續講哦)
//創作不易,點個贊再走唄by——白龍碼
轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/259493.html
標籤:其他
上一篇:Vue框架——分支結構
