書籍使我變成了一個幸福的人,使我的生活變成輕松而舒適的詩?!郀柣?/p>
創(chuàng)新互聯(lián)建站成立與2013年,先為鹽田等服務(wù)建站,鹽田等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為鹽田企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
本文已經(jīng)收錄至我的GitHub,歡迎大家踴躍star 和 issues。
https://github.com/midou-tech/articles
我本來準(zhǔn)備C語言章節(jié)就寫個指針就ok了,在我看來C語言的精華部分就是指針了。但是有很多同學(xué)就開始在群里各種拉扯C語言的其他問題,沒辦法,我是龍叔嘛,想想還是整理一下,把一些重要的C語言知識點都一一更新了吧。C語言指針的內(nèi)容請點擊 指針(上) 和 指針(下),記得點關(guān)注,不迷路
我們把一組數(shù)據(jù)的集合稱為數(shù)組(Array),它所包含的每一個數(shù)據(jù)叫做數(shù)組元素(Element),所包含的數(shù)據(jù)的個數(shù)稱為數(shù)組長度(Length),數(shù)組中的每個元素都有一個序號,這個序號從0開始,而不是從我們熟悉的1開始,稱為下標(biāo)(Index),所包含數(shù)組的里面元素的類型叫做數(shù)組類型(Type)。
一句話就說清楚了數(shù)組的基本概念,就是這么簡單,^_^。
int array[5];
內(nèi)存布局圖
不要看這個圖簡單,底層就是這樣的。數(shù)組是一個整體,它的內(nèi)存是連續(xù)的;也就是說,數(shù)組元素之間是相互挨著的,彼此之間沒有一點點縫隙。
這一點很重要,連續(xù)的內(nèi)存為指針操作(通過指針來訪問數(shù)組元素)和內(nèi)存處理(整塊內(nèi)存的復(fù)制、寫入等)提供了便利,這使得數(shù)組可以作為緩存使用。
有同學(xué)估計要說什么叫做指針操作,聽龍叔絮叨下。
int arr[5] = {1,2,3,4,5};
printf("%d\n",arr[3]);
看上面的代碼,學(xué)過數(shù)組都知道arr[3]是取第三個元素的值,那我就要問你了,怎么取到值的呢???
不要慌,龍叔告訴你其實就是指針操作。當(dāng)我們聲明并定義數(shù)組int arr[5] = {1,2,3,4,5}
,此時數(shù)組被分配了5個int大小的空間在棧上,并初始化了數(shù)組元素。我們都知道數(shù)組名代表數(shù)組的首元素的首地址,那么很明顯就可以得到arr[3] = arr + 3
。指針的加減操作詳情請看龍叔公號,微信搜索 龍躍十二 即可訂閱喔。
int a[] = {1,2,3,4};
printf("%d\n",sizeof(a));
printf("%d\n",sizeof(a+0));
printf("%d\n",sizeof(*a));
printf("%d\n",sizeof(a+1));
printf("%d\n",sizeof(a[1]));
printf("%d\n",sizeof(&a));
printf("%d\n",sizeof(&a+1));
printf("%d\n",sizeof(&a[0]));
printf("%d\n",sizeof(&a[0]+1));
//字符數(shù)組
char arr[] = {'a','b','c','d','e','f'};
printf("%d\n", sizeof(arr));
printf("%d\n", sizeof(arr+0));
printf("%d\n", sizeof(*arr));
printf("%d\n", sizeof(arr[1]));
printf("%d\n", sizeof(&arr));
printf("%d\n", sizeof(&arr+1));
printf("%d\n", sizeof(&arr[0]+1));
printf("%d\n", strlen(arr));
printf("%d\n", strlen(arr+0));
printf("%d\n", strlen(*arr));
printf("%d\n", strlen(arr[1]));
printf("%d\n", strlen(&arr));
printf("%d\n", strlen(&arr+1));
printf("%d\n", strlen(&arr[0]+1));
char *p = "abcdef";printf("%d\n", sizeof(p));
printf("%d\n", sizeof(p+1));
printf("%d\n", sizeof(*p));
printf("%d\n", sizeof(p[0]));
printf("%d\n", sizeof(&p));
printf("%d\n", sizeof(&p+1));
printf("%d\n", sizeof(&p[0]+1));
printf("%d\n", strlen(p));
printf("%d\n", strlen(p+1));
printf("%d\n", strlen(*p));
printf("%d\n", strlen(p[0]));
printf("%d\n", strlen(&p));
printf("%d\n", strlen(&p+1));
printf("%d\n", strlen(&p[0]+1));
//二維數(shù)組
int a[3][4] = {0};
printf("%d\n",sizeof(a));
printf("%d\n",sizeof(a[0][0]));
printf("%d\n",sizeof(a[0]));
printf("%d\n",sizeof(a[0]+1));
printf("%d\n",sizeof(a+1));
printf("%d\n",sizeof(&a[0]+1));
printf("%d\n",sizeof(*a));
printf("%d\n",sizeof(a[3]));
就這幾個運算,估計會難倒很多同學(xué)的,不信你可以把答案寫出來之后在去跑一遍,全對找我拿紅包。
sizeof(數(shù)組名),代表整個數(shù)組的字節(jié)數(shù);&數(shù)組名,代表取得整個數(shù)組的地址。
int arr[5] = {1,2,3,4,5}; int b = arr[10];
,這樣訪問也是可以拿到元素的,天知道你訪問的是誰的數(shù)據(jù)。int b;
scanf("%d",&b);
int arr[3*b];
不知道你曾經(jīng)有沒有寫過這樣的代碼,反正我寫過。數(shù)組的長度和內(nèi)存是在程序編譯時就已經(jīng)確定了的。b的值是在運行時才確定的。有兩個新名詞,程序編譯時&程序運行時。
int arr[5] = {1,2,3,4,5};
printf("%d\n",arr[-1]);
printf("%d\n",arr[1]);
printf("%d\n",arr[4]);
printf("%d\n",arr[5]);
printf("%d\n",arr[6]);
肉眼可見的錯誤,編譯器竟然沒報錯。
利用數(shù)組可以出很多筆試題目,當(dāng)然這些題目很多并不是考驗數(shù)組本身特性大多是考算法基礎(chǔ)的。本節(jié)就到這里了,有什么不清楚的問題歡迎留言喔,也可私信或mail。
往期精彩回顧: