局部内置数组不初始化则含垃圾值;全局/静态数组默认零初始化;C++中默认、零、值、聚合、列表初始化易混淆致未定义行为或编译失败。

数组初始化看似简单,但C++里有多种写法,稍不注意就会触发未定义行为、编译失败或隐式截断——尤其对新手,默认初始化、零初始化、值初始化、聚合初始化、列表初始化之间的区别,是高频出错根源。
局部数组不初始化 = 垃圾值
在函数内部定义的内置类型数组(如 int arr[5]),若不显式初始化,元素值是随机的,不是0。这和全局/静态数组完全不同。
-
错误写法:
void foo() { int a[3]; cout → 输出不可预测 -
正确写法(全部清零):
int a[3] = {};或int a[3] = {0}; - 注意:
int a[3] = {1};实际效果是{1, 0, 0},只初始化首元素,其余零初始化
用花括号初始化时,大小不能省(除非有推导上下文)
直接用 {...} 初始化数组,必须明确指定大小,否则编译报错(C++11起仍不支持推导原生数组大小)。
-
错误写法:
int arr[] = {1,2,3};→ 在函数参数中非法;在局部变量中虽合法,但易引发歧义 -
推荐写法(明确、安全):
int arr[3] = {1,2,3};或 C++11 起更推荐std::array<int> arr = {1,2,3}; </int> - 例外:全局/命名空间作用域下
int arr[] = {1,2,3};是允许的,编译器会推导为 size=3
聚合初始化 vs 列表初始化:大括号里的“=”很关键
C++11 引入统一初始化({}),但加不加等号语义不同,尤其对数组:
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~