C语言的数组(上)

如何创建一个数组

    //创建一个数组-存放整型-10个
    int arr[10] = { 1, 2, 3 };

这样我们就创建了一个一维数组
但是要记住,数组创建,[ ]中要给一个常量才可以,不能使用变量。


数组的初始化:
数组的初始化是指,在创建数组的同时给数组的内容一些合理初始值(初始化)。
例如:

int arr1[10] = {1,2,3};//这样是不完全的初始化,剩下的元素默认初始化为0

数组在创建的时候如果想不指定数组的确定的大小就得初始化。数组的元素个数根据初始化的内容来确定。 但是对于下面的代码要区分,内存中如何分配。

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 计算变量、数组、类型得大小-单位是字节 - 操作符


一维数组的使用
[ ] 下标引用操作符,它其实就是数组访问的操作符。


总结
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]可以看出随着数组下标的增长,元素的地址,也在有规律的递增。 由此可以得出结论:数组在内存中是连续存放的。


接下来是二维数组的创建

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
永远相信傻瓜计算机

猜你喜欢

转载自blog.51cto.com/15080720/2607578