大家好,又见面了,我是你们的朋友全栈君。
前言:本文章主要用于个人复习,追求简洁,感谢大家的参考、交流和搬运,后续可能会继续修改和完善。
因为是个人复习,会有部分压缩和省略。
数组:一组相同类型的元素的集合
一、数组
1.定义一维数组:
int arr[10] = {1,2,3,4,5,6,7,8,9,10};//定义一个整型数组,最多可以放10个元素
注意上述代码中所说的是是个元素,不一定非要是整型元素。
eg.
可以看到,即使是放了一个字符,编译器仍然没有报错,并且运行正常,打印出了字符a的ASCII码值
2.数组创建时其值
数组在创建时,如果只给了数组大小,没有初始化,其中的值会是随机值
如果这样,数组的所有值会被初始化为0。数组在创建并将它初始化时,其会自己推算大小。
#include <stdio.h>
int main()
{
int arr[10] = { 0 };
//当然,这样也可以
int arr[10] = { 0 , 0 };
//这样是不可以的,不要觉得是0就可以为所欲为
int arr[5] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
//如果这样写
int arr[10] = { 1, 2, 3 };
//这样是不完全初始化,即数组前三个元素分别初始化为1,2,3,其余元素均默认为0
return 0;
}
下面这种情况,当只给了值而没有给数组大小时,数组会自己推算大小
数组创建时,数组大小的指定需要一个常量不能是变量[]内应为常量(即使是const修饰过称为常变量的 值也不可以)
PS:const修饰的变量被称为常变量,本质是变量,但不能用在数组定义时指定大小
因为[]是一个运算符,所以这样写也可以,二者等价(之前有的地方是可以的,但是在VS2019好像并不可以,改天我再看看)
int arr[10] = { 0 };
int 10[arr] = { 0 };
3.C语言规定:数组的每个元素都有下标,且下标是从0开始的。
4.数组的使用
我们可以通过使用数组中元素的下标来访问元素
5.数组使用时可能出现的错误
当我们不小心将数组下标搞错时,就有可能出现下面这种情况
越界访问:
其中有一个经典题型:
#include <stdio.h>
int main()
{
int i = 0;
int arr[10] = {0};
for(i=0; i<=12; i++)
{
arr[i] = 0;
printf("hello world!\n");
}
return 0;
}
该题中对于数组的调用本身是越界的,但是由于在创建i变量时,刚好和所赋值的arr[12]空间重合,值变成0,所以该程序在某些debug环境下运行的结果是一个死循环。
数组中字符串隐藏的’\0’影响数组大小:
注意此处,”abcdef”中隐藏了’\0’,虽然arr长度为6,但其实际元素个数是7。我们通过调试就能看出来。
下标为0~6,共7个元素,大小为7。
6.判断两个数组类型是否相同:
数组只要类型发生变化或者元素个数发生变化,整体类型就发生了变化
int main()
{
int arr1[10] = { 0 };
char arr2[10] = { 0 };
char arr3[7] = { 0 };
return 0;
}
此代码中三个数组类型都不相同。
7.数组传参
数组在传参时,传递的不是整个数组,而是数组首元素的地址,所以若在函数中计算sz,会出现bug。
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/163002.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...