如何建立一個數組數組
//建立一個數組-存放整型-10個 int arr[10] = { 1, 2, 3 };
這樣咱們就建立了一個一維數組
可是要記住,數組建立,[ ]中要給一個常量才能夠,不能使用變量。ide
數組的初始化:
數組的初始化是指,在建立數組的同時給數組的內容一些合理初始值(初始化)。
例如:函數
int arr1[10] = {1,2,3};//這樣是不徹底的初始化,剩下的元素默認初始化爲0
數組在建立的時候若是想不指定數組的肯定的大小就得初始化。數組的元素個數根據初始化的內容來肯定。 可是對於下面的代碼要區分,內存中如何分配。3d
int main() { char arr4[] = "abcdef"; printf("%d\n", sizeof(arr4)); //sizeof 計算 arr4所佔空間的大小 //7個元素-char 7*1 = 7 printf("%d\n", strlen(arr4)); //strlen 求字符串的長度 -'\0'以前的字符個數 //[abcdef\0] //6 return 0; }
這裏咱們要知道strlen和sizeof的區別
1.strlen 和 sizeof沒有什麼關聯
2.strlen是求字符串串長度的-只能針對字符串求長度 - 庫函數 - 使用得引用頭文件
3.sizeof 計算變量、數組、類型得大小-單位是字節 - 操做符code
一維數組的使用
[ ] 下標引用操做符,它其實就是數組訪問的操做符。blog
總結
1.數組是使用下標來訪問得,下標是從0開始。
2.數組的大小能夠經過計算獲得。內存
一維數組在內存中的存儲字符串
int main() { int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; int sz = sizeof(arr) / sizeof(arr[0]); int i = 0; for (i = 0; i < sz; i++) { printf("&arr[%d] = %p\n",i, &arr[i]); } }
以上是輸出的結果,從arr[0]到arr[9]能夠看出隨着數組下標的增加,元素的地址,也在有規律的遞增。 由此能夠得出結論:數組在內存中是連續存放的。it
接下來是二維數組的建立class
int arr[3][4]; char arr[3][5]; float arr[2][4];
二維數組的初始化
int arr[3][4] = {1,2,3,4}; int arr[3][4] = {{1,2},{3,4}}; int arr[][4] = {{1,2},{3,4}};
這時眼尖的小夥伴能夠發現第三個二維數組的前面一個表明行的[ ]裏沒有數字,由於在二維數組裏,二維數組的初始化行能夠省略可是列不能夠省略。(補充:int arr[3][4]表明建立了三行四列)
二維數組的使用
二維數組的使用也是經過下標的方式。
二維數組在內存中的存儲
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", i, j, &arr[i][j]); } } return 0; }
打印結果:
經過結果咱們能夠看出,跟一維數組同樣,二維數組在內存中也是連續存儲的。
2021.1.26永遠相信傻瓜計算機