如何建立一个数组数组
//建立一个数组-存放整型-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永远相信傻瓜计算机