C语言的数组(上)

如何建立一个数组数组

//建立一个数组-存放整型-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]);
    }
}

C语言的数组(上)
以上是输出的结果,从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;
}

打印结果:
C语言的数组(上)
经过结果咱们能够看出,跟一维数组同样,二维数组在内存中也是连续存储的。

2021.1.26永远相信傻瓜计算机

相关文章
相关标签/搜索