最安全初始化方式是std::array a = {};或std::vector v(1000);,前者全零且编译期检查,后者自动管理内存;裸数组用int arr[100] = {};,动态数组用std::fill或new int[n]();。

用 std::array 初始化时直接列表赋值最安全
现代 C++ 推荐优先用 std::array 替代裸数组,初始化清晰且不会退化为指针。它支持聚合初始化,编译期检查长度,还能自动推导类型。
常见错误是写成 std::array<int> a = {0};</int>——这只会初始化第一个元素为 0,其余未定义(不是清零)。必须显式写出全部初始值或用空花括号。
std::array<int> a = {}; // 全零初始化,推荐</int>std::array<int> b{1, 2, 3}; // 显式赋值</int>- 别写
std::array<int> c = {0};</int>,后两个元素值不确定
裸数组用 memset 清零要小心类型和范围
memset 快但危险:它按字节填充,只适合 POD 类型(如 int、char),对含构造函数或虚函数的类会破坏对象状态。
另一个坑是传错大小:用 sizeof(arr) 没问题,但若传入指针(比如函数参数),sizeof 就失效了,结果是只清了指针本身(8 字节)。
立即学习“C++免费学习笔记(深入)”;
int arr[100] = {}; // 编译期清零,最简单,推荐用于栈数组memset(arr, 0, sizeof(arr)); // 正确:arr 是数组名,sizeof 有效memset(ptr, 0, n * sizeof(*ptr)); // 函数内清零指针,必须手动算大小- 别对
std::string数组或自定义类数组用memset
动态数组(new int[n])必须用 std::fill 或循环
用 new[] 分配的数组不能靠 = {} 初始化,也不能直接用 memset(除非你确认类型安全且记得除以 sizeof(int))。更现代、更明确的做法是用 std::fill。
性能上,std::fill 和 memset 在优化后通常一样快,但它语义清晰、类型安全、可读性高。
int* p = new int[1000]; std::fill(p, p + 1000, 0); // 推荐int* q = new int[1000](); // 注意小括号:带 () 才能值初始化为 0- 别写
new int[1000]{}—— C++11 起语法允许,但部分老编译器不支持 - 用完记得
delete[] p;,漏掉就是内存泄漏
用 std::vector 初始化比裸数组省心得多
除非有硬性性能/内存布局要求,否则直接用 std::vector。它默认构造就清零(对于 int 等内置类型),且能自动管理生命周期。
注意:std::vector<int>(n)</int> 和 std::vector<int>(n, 0)</int> 效果一样,都是 n 个 0;但 std::vector<int> v(n)</int> 在声明时就完成初始化,不额外调用 fill 或 memset。
std::vector<int> v(1000); // 全 0,安全、简洁、无内存管理负担</int>v.assign(1000, 0); // 运行时重置为全 0- 避免
vector<char> buf(1024); memset(&buf[0], 0, buf.size());</char>—— 多余且易出错
真正容易被忽略的是:数组是否在栈上、是否是 POD 类型、是否会被传递进函数——这三个条件一变,初始化方式就得跟着换。没想清楚这点,再“快捷”的写法都可能埋雷。









