最安全通用的方式是声明时用{}初始化(栈数组)或std::fill(运行时),memset仅限POD类型;{}保证内置类型零初始化,std::fill支持任意可赋值类型,memset误用于非POD将导致未定义行为。

C++数组怎么快速初始化_C++数组清零与赋值多种方法【基础】

直接说结论:C++ 数组初始化和清零,最安全、最通用的方式是用 std::fillstd::memset(仅限 POD 类型),而声明时初始化优先用花括号列表;千万别依赖未定义行为或误用 memset 给非 POD 类型清零。

声明时用 {} 初始化最简洁可靠

对于栈上数组,声明即初始化是最省心的方式。C++11 起支持统一初始化语法,能避免窄化警告,且对内置类型自动补零:

int arr1[5] = {};           // 全部为 0
double arr2[3] = {1.0};     // arr2[0]=1.0, arr2[1]=arr2[2]=0.0
char buf[100] = {};         // 所有字节为 0,适合后续 strcpy 等操作

std::fill 是运行时赋值的首选

当数组已存在、需在运行时重置或批量赋值时,std::fill 安全、泛型、无类型限制:

#include <algorithm>
int arr[10];
std::fill(arr, arr + 10, 42);    // 全设为 42
std::fill(arr, arr + 10, 0);     // 清零,等效但比 memset 更安全

memset 快但只适合 POD 类型清零

memset 是底层字节填充,快,但危险——它不管类型,只按字节写值:

#include <cstring>
int arr[10];
memset(arr, 0, sizeof(arr));  // ✅ 安全:int 是 POD,全 0 字节即值为 0
struct S { std::string s; int x; };
S obj;
memset(&obj, 0, sizeof(obj)); // ❌ 危险:破坏 string 内部指针,后续析构崩溃

动态数组(new[])和 std::vector 的初始化差异

堆上数组不能用 {} 直接初始化,容易出错;std::vector 是更现代的选择:

// ❌ 错误:new int[5]{} 在 C++11+ 合法,但易被忽略
int* p = new int[5]{};  // ✅ 实际可行,但不如 vector 直观

// ✅ 推荐:vector 自动管理,初始化明确 std::vector<int> v1(5, 0); // 5 个 0 std::vector<int> v2(5, 42); // 5 个 42 std::vector<int> v3{1,2,3}; // 列表初始化

真正容易被忽略的是类型安全性:给 std::string 数组用 memset 清零,程序可能当场崩溃或延后崩溃;而 std::fill 会调用每个对象的赋值运算符,哪怕慢一点,也绝不会越界或破坏对象状态。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。