目錄
- 一維數組
- 數組的創建
- 初始化
- 使用
- 在內存中的存儲
- 二維數組
- 創建
- 初始化
- 使用
- 在內存中的存儲
- 數組越界
一維數組
數組的創建
數組是一組相同類型元素的集合。
int arr1[10];
char arr3[10];
float arr4[10];
double arr5[10];
下面這個數組能否成功創建?
int count = 10;
int arr2[count];
**注:**在C99標準之前, [] 中要給一個常量才可以,不能使用變量。在C99標準支持了變長數組的概念,數組的大小可以使用變量指定,但是數組不能初始化。不過在C90標準下仍然有一些不能實現,所以具體能否實現還是要看編譯環境。
初始化
int arr1[10] = {1,2,3};
int arr2[] = {1,2,3,4};
int arr3[5] = {1,2,3,4,5};
char arr4[3] = {'a',98, 'c'};
char arr5[] = {'a','b','c'};
char arr6[] = "abcdef";
上述都是正確的數組初始化,數組在創建的時候如果想不指定數組的確定的大小就得初始化。數組的元素個數根據初始化的內容來確定。
char arr1[] = "abc";
char arr2[3] = {'a','b','c'};
這兩行代碼都是給數組初始化為abc三個字符,但是在內存中的分配是不一樣的。
使用
我們之前介紹了一個操作符: [] ,下標引用操作符。它其實就數組訪問的操作符。
#include <stdio.h>
int main()
{int arr[10] = { 0 };//數組的不完全初始化//計算數組的元素個數int sz = sizeof(arr) / sizeof(arr[0]);//對數組內容賦值,數組是使用下標來訪問的,下標從0開始。所以:int i = 0;//做下標for (i = 0; i < 10; i++){arr[i] = i;}//輸出數組的內容for (i = 0; i < 10; ++i){printf("%d ", arr[i]);}return 0;
}
注意:
- 數組是通過下標來訪問的,下標是從0開始。
- 數組的大小可以通過計算得到。
int arr[10];
int sz = sizeof(arr)/sizeof(arr[0]);
在內存中的存儲
#include <stdio.h>
int main()
{
int arr[10] = {0};
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;
}
我們通過打印地址來觀察數組在內存中的存吃是怎么樣的?
十六進制是從0 ~ 9,A ~ F(相當于10~15),觀察輸出的結果,可以發現當下標增長1,元素的地址增加4,從低地址到高地址非常有規律地增加,數組在內存中是連續存放的
二維數組
創建
int arr[3][4];
char arr[3][5];
double arr[2][4];
初始化
int arr[3][4] = {1,2,3,4};
int arr[3][4] = {{1,2},{4,5}};
int arr[][4] = {{2,3},{4,5}};
注意:
二維數組如果有初始化,行可以省略,列不能省略。
int arr[][4] = {{2,3},{4,5}}; //正確寫法
int arr[4][] = {{2,3},{4,5}}; //錯誤寫法
使用
和一維數組一樣通過下標訪問。
#include <stdio.h>
int main()
{int arr[3][4] = { 0 };int i = 0;for (i = 0; i < 3; i++){int j = 0;for (j = 0; j < 4; j++){arr[i][j] = i * 4 + j;}}for (i = 0; i < 3; i++){int j = 0;for (j = 0; j < 4; j++){printf("%d\t", arr[i][j]); //為了好看加制表符并換兩行}printf("\n\n"); }return 0;
}
在內存中的存儲
#include <stdio.h>
int main()
{int arr[3][4];int i = 0;for (i = 0; i < 3; i++){int j = 0;for (j = 0; j < 4; j++){printf("&arr[%d][%d] = %p\n\n", i, j, &arr[i][j]);}}return 0;
}
通過觀察我們發現二維數組在內存中也是從低地址到高地址連續存儲的。
數組越界
數組的下標是有范圍限制的。
數組的下規定是從0開始的,如果數組有n個元素,最后一個元素的下標就是n-1。
所以數組的下標如果小于0,或者大于n-1,就是數組越界訪問了,超出了數組合法空間的訪問。
C語言本身是不做數組下標的越界檢查,編譯器也不一定報錯,但是編譯器不報錯,并不意味著程序就是正確的,所以程序員寫代碼時,最好自己做越界的檢查。
#include <stdio.h>
int main()
{
int arr[10] = {1,2,3,4,5,6,7,8,9,10};int i = 0;for(i=0; i<=10; i++){printf("%d\n", arr[i]);//當i等于10的時候,越界訪問了}
return 0;
}
二維數組也存在行或列可能越界的問題。