局部内置数组不初始化则含垃圾值;全局/静态数组默认零初始化;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=3C++11 引入统一初始化({}),但加不加等号语义不同,尤其对数组:
立即学习“C++免费学习笔记(深入)”;
int a[3]{1,2}; → 聚合初始化,等价于 {1,2,0}(剩余元素零初始化)int a[3] = {1,2}; → 也是聚合初始化,行为同上,= 在这里是语法糖,非赋值int a[3] = {1,2,3,4}; → 编译错误!初始化器过多,不允许截断int a[3] = {1.5, 2.7, 3}; → 允许,但 1.5 和 2.7 会被隐式截断为 1 和 2(窄化转换,C++11 起部分编译器会警告)用 new int[5] 分配的数组,无法用 {1,2,3,4,5} 直接初始化(直到 C++11 才支持,且需编译器兼容)。
int* p = new int[5]; // 全是垃圾值
std::vector<int> v{1,2,3,4,5}; </int>(最安全、自动管理)auto ptr = std::make_unique<int>(5); </int> 再逐个赋值int* p = new int[5]{1,2,3,4,5}; (C++11 支持,但不推荐)基本上就这些。核心记住三点:局部数组不初始化就是垃圾;花括号初始化要配大小;能用 std::array 或 std::vector 就别碰裸数组。不复杂但容易忽略。
以上就是C++数组初始化方式讲解_C++新手易错点解析的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号