数组

本文深入探讨了C++中数组初始化的规则和特性,包括内置数组、类类型数组的初始化方式,以及如何使用字符串和字符字面量初始化字符数组。详细解释了数组初始化的多种情况和注意事项,帮助开发者更好地理解和运用C++数组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果没有 显式提供元素初值,则数组元素会像普通变量一样初始化:

1.在函数体外定义的内置数组,其元素均初始化为0

2.在函数体内定义的内置数组,其元素无初始化。

3.不管数组在哪里定义的,如果其元素为类类型,则自动调用该类的默认构造函数进行初始化;如果该类没有默认构造函数,则必须为该数组的元素提供显示初始化。

注:除非显示地提供元素初值,否则内置类型的局部数组的元素没有初始化。此时,除了给元素赋值外,其他使用这些元素的操作没有定义。

显式初始化的数组不需要指定数组的维数值,编译器会根据列出的元素个数来确定数组的长度。

如果指定了数组维数,那么初始化列表提供的元素个数不能超过维数值。如果维数大于列出的元素初值个数,则只初始化前面的数组元素,剩下的其他元素,若是内置类型则初始化为0,若是类类型则调用该类的默认构造函数进行初始化。


字符数组既可以用一组由花括号括起来,逗号隔开的字符字面值进行初始化,也可以用一个字符串字面值进行初始化。

两种初始化形式并不完全相同字符串字面值包含一个额外的空字符NULL用于结束字符串。

当使用字符串字面值来初始化创建的新数组时,将在新数组中加入空字符。

char  ca3[]  =  "C++"    //ca3的维数是4

使用一组字符字面值初始化字符数组时,一定要记得添加结束字符串的空字符。否则,将导致编译时的错误。

与vector不同,一个数组不能用另一个数组初始化,也不能将一个数组赋值给另一个数组,这些操作都是非法的。

注:一些编译器允许将数组赋值作为编译器扩展。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值