0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

C语言中的数组格式与初始化

单片机与嵌入式 来源:单片机与嵌入式 2023-11-26 16:12 次阅读

数组:只能存放一种数据类型,比如int类型的数组、float类型的数组,里面存放的数据称为“元素”。

数组的定义:

首先声明数组的类型,然后声明数组元素的个数,也就是定义需要多少存储空间。

数组格式与初始化

格式:

元素类型 数组名[元素个数];

比如:

int[3];

数组元素有顺序之分,每个元素都有一个唯一的下标(索引),而且都是从0开始。

数组中第i个元素的访问方式:

a[i]

数组元素的初始化:

int a[3] = {10, 9, 6};
int a[3] = {10,9};
int a[] = {11, 7, 6};
int a[4] = {[1]=11,[0] = 7};

[ ]里面的个数必须是一个固定值,可以是常量(比如6、8)、常量表达式(比如3+4、5*7)。绝对不能使用变量或者变量表达式来表示元素个数,大多数情况下不要省略元素个数,当数组作为函数的形参和数组初始化时除外。

C语言中编译器是不会对数组下标越界进行检查的,所以自己访问数组元素时要注意。

一维数组

数组的内存细节分析

#include
int main()
{
charcs[5]={'a','A','D','e','f'};
printf("%p
",cs);//数组名就代表数组的地址
    for (int i = 0; i<5; i++)
    {
        printf("cs[%d]的地址是:%p
",i ,&cs[i]);
    }
    return 0;
}

上面代码中,地址分配分析如下:

2684065c-8c12-11ee-939d-92fbcf53809c.png

一维数组的元素作为函数实参,与同类型的简单变量作为实参一样,是单向的值传递,即数组元素的值传给形参,从而形参是改变不影响实参。

数组名代表着整个数组的地址,如果一维数组的名字作为函数实参,传递的是整个数组,即形参数组和实参数组完全相同,是存放在同一存储空间的同一个数组。这样形参数组修改时,实参数组也同时被修改了。形参数组的元素个数可以省略。

// b是test函数的形参(形式参数)
void test(int b) {
    b = 9;
}
int main()
{
    int a[3];
a[0]=10;
printf("函数调用前的a[0]:%d
",a[0]);
test(a[0]);//a[0]是test函数的实参(实际参数)
    printf("函数调用后的a[0]:%d", a[0]);
    return 0;
}

#include
//数组作为函数参数,可以省略元素个数
//数组作为函数参数,传递是整个数组的地址,修改了函数形参数组元素的值,会影响到外面的实参数组
void change(int array[])
{
printf("array==%p
",array);
    array[0] = 100;
}
int main()
{
intages[6]={10,11,13,15,11,18};
printf("array==%p
",ages);
change(ages);
printf("%d
",ages[0]);
return0;
}

输出结果为:

array==0x7fff5be26c00
array ==0x7fff5be26c00
100

数组的小练习,找最大值:

/*
设计一个函数,找出整型数组元素的最大值
*/
 
#include 
 
int maxOfArray(int array[], int length)
{
    // 数组当做函数参数传递时,会当做指针变量来使用,指针变量在64bit编译器环境下,占据8个字节
    
    //int size = sizeof(array);
    //printf("array=%d
", size);
    
    //sizeof(array);
    
    // 1.定义一个变量存储最大值(默认就是首元素)
    int max = array[0];
    
    // 2.遍历所有元素,找出最大值
    for (int i = 1; i max)
        {
            max = array[i];
        }
    }
    
    return max;
}
 
int main()
{
    int ages[] = {11, 90, 67, 150, 78, 60, 70, 89, 100};
    
    int ages2[] = {11, 90, 67, 150, 78, 60, 70, 89, 100};
    
    //int size = sizeof(ages);
    
    //printf("ages=%d
", size);
    int max = maxOfArray(ages, sizeof(ages)/sizeof(int));
    
    printf("%d
", max);
    return 0;
}

二维数组

一个数组能表示一个班人的年龄,如果想表示很多班呢?

什么是二维数组?int ages[3][10]; 三个班,每个班10个人,相当于3行10列,相当于装着3个一维数组。

二维数组是一个特殊的一维数组:它的元素是一维数组。例如int a[2][3]可以看作由一维数组a[0]和一维数组a[1]组成,这两个一维数组都包含了3个int类型的元素。

定义形式:

类型  数组名[ 行数] [列数]
int  a[2][3];   //2行3列的二维数组

二维数组的存放顺序是按行存放的,先存放第一行的元素,再存放第2行的元素。例如int a[2][3]的存放顺序是:

a[0][0] → a[0][1] → a[0][2] → a[1][0] → a[1][1] → a[1][2]

二维数组的内存存储分配

269b628e-8c12-11ee-939d-92fbcf53809c.png

注意:a[0]、a[1]也是数组,是一维数组,而且a[0]、a[1]就是数组名,因此a[0]、a[1]就代表着这个一维数组的地址。

数组a的地址是ffc1,数组a[0]的地址也是ffc1,即a = a[0]

元素a[0][0]的地址是ffc1,所以数组a[0]的地址和元素a[0][0]的地址相同,即a[0] = &a[0][0]

最终可以得出结论:a = a[0] = &a[0][0],以此类推,可以得出a[1] = &a[1][0]

二维数组的初始化:

intages2[3][5]={
{10,11,90,89,70},
{10,11,90,89,70},
        {10, 11, 90, 89, 70}
    };

审核编辑:彭菁

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 存储
    +关注

    关注

    13

    文章

    4328

    浏览量

    85943
  • C语言
    +关注

    关注

    180

    文章

    7608

    浏览量

    137111
  • 元素
    +关注

    关注

    0

    文章

    47

    浏览量

    8449
  • 数组
    +关注

    关注

    1

    文章

    417

    浏览量

    25978

原文标题:总结C语言中的数组知识点

文章出处:【微信号:单片机与嵌入式,微信公众号:单片机与嵌入式】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    C语言中初始化的局部变量到底是多少

    C语言中,未初始化的局部变量到底是多少?
    发表于 10-21 14:42 2045次阅读

    C语言中数组和结构体的内存表示和布局

    C语言中数组和结构体都可以代表一块内存,但为什么结构体可以直接赋值,而数组不可以?这个问题涉及到C语言
    发表于 08-28 10:54 1663次阅读

    【原创分享】变量的初始化技巧

    由于在嵌入式系统中必须考虑程序规模的问题,因此,对程序中的变量的初始化也需要进行慎重的考虑。在C语言中,基本数据结构(字符型、整型)的初始化相对简单;
    发表于 09-08 15:28

    c语言二维数组初始化及使用

    二维数组初始化也是在类型说明时给各下标变量赋以初值。二维数组可按行分段赋值,也可按行连续赋值。 数组是一种构造类型的数据。二维数组可以看作是
    发表于 11-16 09:15 2w次阅读
    <b class='flag-5'>c</b><b class='flag-5'>语言</b>二维<b class='flag-5'>数组</b><b class='flag-5'>初始化</b>及使用

    c语言二维数组如何初始化为0

    c语言二维数组如何初始化: 有两种方法:1.在定义时可以直接赋值来初始化2.在定义后可以为其元素一个个来赋值。
    发表于 11-16 09:43 4.1w次阅读
    <b class='flag-5'>c</b><b class='flag-5'>语言</b>二维<b class='flag-5'>数组</b>如何<b class='flag-5'>初始化</b>为0

    19-C语言中数组知识汇总

    类型名(int[10]) + 变量名(arr) 2.数组完全初始化 #includestdio.h int main(void){int arr[ 5 ] = { 1 , 2 , 3 , 4 , 5
    发表于 11-28 11:57 1135次阅读

    EE-88:使用21xx编译器初始化C语言中的变量

    EE-88:使用21xx编译器初始化C语言中的变量
    发表于 05-19 21:08 1次下载
    EE-88:使用21xx编译器<b class='flag-5'>初始化</b><b class='flag-5'>C</b><b class='flag-5'>语言中</b>的变量

    C语言中指针与数组

    #define SIZE 10int arry[SIZE]={0,1,2,3,4,5,6,7,8,9}; //数组名arry表示数组首元素的地址*int p,temp;//可直接初始化定义指针
    发表于 01-13 13:11 3次下载
    <b class='flag-5'>C</b><b class='flag-5'>语言中</b>指针与<b class='flag-5'>数组</b>

    C语言指定初始化器解析及其应用

    C90 标准要求初始化程序中的元素以固定的顺序出现,与要初始化数组或结构体中的元素顺序相同。但是在新标准 C99 中,增加了一个新的特..
    发表于 02-07 11:28 2次下载
    <b class='flag-5'>C</b><b class='flag-5'>语言</b>指定<b class='flag-5'>初始化</b>器解析及其应用

    C语言中的char数组和char指针有什么区别?

    让我们通过下面的例子,来了解 C语言中字符数组和字符指针之间的区别。
    的头像 发表于 01-29 16:35 2762次阅读

    C语言中数组空间动态开辟

    C语言中数组空间动态开辟 在C语言中,必不可少的需要使用到数组,通常为了动态的开辟
    的头像 发表于 02-10 12:42 2191次阅读

    C语言中数组在内存中如何表示

    C语言中数组在内存中是怎样表示的,今天就给大家聊聊这个话题。
    的头像 发表于 02-15 14:35 949次阅读
    <b class='flag-5'>C</b><b class='flag-5'>语言中</b><b class='flag-5'>数组</b>在内存中如何表示

    C语言中什么是指针数组

    C语言中一个数组,若其元素均为指针类型数据,称为指针数组,也就是说,指针数组中的每一个元素都存放一个地址,相当于一个指针变量。
    的头像 发表于 03-10 15:26 1808次阅读

    c语言中数组怎么定义

    C语言中数组是一种用来存储相同类型元素的数据结构。它可以存储多个元素,并通过一个共同的名称来引用这些元素。数组是一种很重要的数据结构,可以用于解决很多实际的问题。 在
    的头像 发表于 11-24 10:11 3146次阅读

    C语言编程时,各种类型的变量该如何初始化

    C语言编程时,各种类型的变量该如何初始化? 在C语言中,每个变量都需要在使用之前进行初始化
    的头像 发表于 12-07 13:53 1256次阅读