c语言定义二位指针数组初始化,9.6.1 二维数组的定义和初始化

9.6  二维数组

C语言中允许我们定义多维数组。但是实际的项目中,我们最常用的就是二维数组,所以下面以二位数组为例进行讲解,多维数组的原理和使用于此类似。

9.6.1  二维数组的定义和初始化

每个一维数组都是有数据类型的。例如,整型一维数组,那么数组中每一个元素都是整型;浮点型一维数组,那么数组中每一个元素都是浮点型;或者字符型一维数组,那么数组中每一个元素都是字符型。如果我们定义了自己的数据类型-xx型,那么我们也可以定义一个xx型一维数组。而xx可以是任何东东。既然xx可以是任何东东,魔法就在一瞬间产生了。如果xx本身就是一维数组,那么我们就定义了一维数组型一维数组。这样,数组中每个元素都是一个一维数组。其实这个魔法有一个专业的名字,在计算机科学领域叫递归。

有点绕口啊!但是这对理解二维数组有很大的帮助,尤其是当我们讲解指针的时候。虽然C语言中可以写int a[2][3],但那只是一种简写方式。事实上,C语言只有一维数组,没有二维数组。二维数组在内部只是被当成一维数组型一维数组。

二维数组的初始化方法可以借鉴一维数组的方法,如程序9-5第1行所示。这种写法是可以的,但不是非常的醒目。更好的办法是用大括号来界定对应的行,如程序程序9-5第2行所示;或者如程序9-5第3行所示,省略行的维度,由初始化的数据决定。

程序9-5  二维数组的初始化

729cb61cdc70c4615108b4942a48029c.png

注意一点,初始化的时候,int a[][3]是可以的,但是int a[2][]却不行。这是因为当我们声明xx型一维数组时,一维数组的长度可以通过初始化表达式来隐含地定义,但是xx型的长度必须是确定的,以便编译器为每一个xx型分配对应的内存。如果xx型的长度不确定,编译器会报错。二维数组中,每个元素就是一个一维数组,其中的一维数组长度必须指定,也就是说,列的长度必须指定。另外,在后面,当介绍指向数组的指针和指向指针的针时,正确地理解二维数组也是非常必要的。

【责任编辑:book TEL:(010)68476606】

点赞 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值