您好,登錄后才能下訂單哦!
 我們把一組數據的集合稱為數組(Array),它所包含的每一個數據叫做數組元素(Element),所包含的數據的個數稱為數組長度(Length),數組中的每個元素都有一個序號,這個序號從0開始,而不是從我們熟悉的1開始,稱為下標(Index),所包含數組的里面元素的類型叫做數組類型(Type)。
 一句話就說清楚了數組的基本概念,就是這么簡單,^_^。
int array[5];
內存布局圖
 不要看這個圖簡單,底層就是這樣的。數組是一個整體,它的內存是連續的;也就是說,數組元素之間是相互挨著的,彼此之間沒有一點點縫隙。
 這一點很重要,連續的內存為指針操作(通過指針來訪問數組元素)和內存處理(整塊內存的復制、寫入等)提供了便利,這使得數組可以作為緩存使用。
 有同學估計要說什么叫做指針操作,聽龍叔絮叨下。
int arr[5] = {1,2,3,4,5};
printf("%d\n",arr[3]);
 看上面的代碼,學過數組都知道arr[3]是取第三個元素的值,那我就要問你了,怎么取到值的呢???
 不要慌,龍叔告訴你其實就是指針操作。當我們聲明并定義數組int arr[5] = {1,2,3,4,5}
,此時數組被分配了5個int大小的空間在棧上,并初始化了數組元素。我們都知道數組名代表數組的首元素的首地址,那么很明顯就可以得到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));
//字符數組
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));
//二維數組
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]));
sizeof(數組名),代表整個數組的字節數;&數組名,代表取得整個數組的地址。
int arr[5] = {1,2,3,4,5}; int b = arr[10];
,這樣訪問也是可以拿到元素的,天知道你訪問的是誰的數據。int b;
scanf("%d",&b);
int arr[3*b];
 不知道你曾經有沒有寫過這樣的代碼,反正我寫過。數組的長度和內存是在程序編譯時就已經確定了的。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]);
肉眼可見的錯誤,編譯器竟然沒報錯。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。