深刻懂得c說話數組。本站提示廣大學習愛好者:(深刻懂得c說話數組)文章只能為提供參考,不一定能成為您想要的結果。以下是深刻懂得c說話數組正文
一 數組名是甚麼
數組就是一段持續可用的內存。
好比聲明一個 int數組
int array[]={1,2,3};
array代表甚麼?有的材料說:數組名是指向數組首地址的常量指針。
上面我們可以驗證一下。
我都曉得sizeof操作符可以前往一個對象或許類型所占的內存字節數。
如:
int i=1;
那末sizeof(i) 的成果就是4(64位機械下的部門編譯器是8)
那我們打印sizeof(array)
printf("%d\n",sizeof(array));
成果是:12。
然則我們都曉得sizeof(指針變量)==4的。
一切我們得出:數組名不完整是指向數組首地址的常量指針。
為何要用不完整,由於我們應用數組來拜訪數組元素的時刻。它又變得像一個常量指針。
好比
array[0]等效於*(array+0)
這時候候 array就是一個指向數組首地址的常量指針,指針類型是指向數組元素類型的指針。這裡就是 int*類型
我們可以如許懂得:
一個年夜學的名字叫array。
有人問你array是甚麼。你會告知他array是年夜學,面積若干之類的。
然則有人問你去array怎樣走,你會告知他array的校門(首地址)在哪裡。
結論:數組名其實代表的是一個內存區域,然則應用的時刻釀成了 指向數組首地址的常量指針。
然則這裡還有一個小圈套:
#include <stdio.h>
void foo(int a[])
{
printf("%d\n",sizeof(a));
}
int main(void)
{
int array[]={1,2,3};
foo(array);
return 0;
}
輸入的不是12,而是4。
出於效力的斟酌,數組傳參是援用傳參而不是拷貝傳參。由於數組長度能夠很年夜,拷貝一份的話太耗資本。
固然我是如許函數是如許的
void foo(int a[])
{
printf("%d\n",sizeof(a));
}
編譯器的眼中是如許
void foo(int *a)
{
printf("%d\n",sizeof(a));
}
所以sizeof(a)是sizeof(指針變量)確定是4;
二 字符數組
起首我們看一個簡略的法式
# include <stdio.h>
int main(void)
{
char *str1="abc";
char str2[]="def";
printf("%s\n",str1+4);
return 0;
}
輸入的成果是 def。
我們要曉得c說話中只需用到了 "xxxxx",體系都邑主動的把雙引號的內容添加到字符常量區。
留意:printf("xxxx");不會把"xxxx"添加到字符常量區。
char *str1="abc"; //會把 abc\0 添加到字符常量區,並把首地址賦值給str指針變量。
char str2[]="def"; //會把 def\0 添加到字符常量區,而且函數棧中添加一個字符數組 內容也是 def\0,str2指向的是棧中的數組。
char str[]={'x','y','z'}; //只會在函數棧中添加數組
因為字符常量區是持續的,所以
printf("%s\n",str1+4);
可以打印出str2的值。
三 二維數組
int array[][3]={1,2,3,4,5,6};
後面我們曾經說了,應用array拜訪元素時,array就是一個指針類型為指向數組元素的指針類型,指向數組首地址的指針。
二維數組的元素就是數組,
如許寫就更輕易懂得:
int array[][3]={{1,2,3},{4,5,6}};
一切可以 如許以為 array是如許以為的
int (*const array)[3];
當我拜訪數組元素時刻
array[x][y]在編譯器看來就是 *(*(array+x)+y)
*(array+x) 獲得的是一個 第x行 類型為 “int[3]”(c說話沒有如許的寫法) 的數組,
數組名在拜訪元素的時刻當作首地址指針來用,在這裡 *(array+x)同等於數組名,
指針類型int *,指向的地址為 array+sizeof(int(*)[3])*x。
拜訪這個數組的第y個元素的時刻,就要用 *(*(array+x)+y)。
這些就是我對c說話數組的懂得,假如毛病的處所,感謝斧正,輕噴哈。