c++中std::array和普通数组的区别_C++标准定长数组与原生数组对比

std::array相比普通数组更安全且支持STL操作,因其不退化为指针,可直接获取尺寸,提供类型安全和丰富接口。

在C++中,std::array普通数组(原生数组) 都用于存储固定数量的同类型元素,但它们在使用方式、功能和安全性上有显著区别。虽然底层行为相似,但 std::array 提供了更现代、更安全、更符合 STL 风格的接口。

1. 类型安全与尺寸获取

普通数组 在作为函数参数传递时会退化为指针,导致无法直接获取其长度:

int arr[5] = {1, 2, 3, 4, 5};
void func(int a[]) { /* a 是 int*,sizeof(a) == 指针大小 */ }
func(arr); // 尺寸信息丢失

std::array 是一个聚合类模板,保留了尺寸信息,可通过 size() 成员函数获取元素个数:

std::array arr = {1, 2, 3, 4, 5};
void func(const std::array& a) {
  std::cout }

2. 支持拷贝与赋值

原生数组不能直接拷贝或赋值:

int a[3] = {1, 2, 3};
int b[3];
b = a; // 编译错误!数组不可赋值

std::array 可以像普通对象一样进行拷贝和赋值:

std::array a = {1, 2, 3};
std::array b = a; // 正确:拷贝构造
b = a; // 正确:赋值操作

3. 与 STL 算法和容器兼容

std::array 提供 begin()/end() 成员函数,可无缝配合 STL 算法:

std::array arr = {4, 2, 5, 1, 3};
std::sort(arr.begin(), arr.end()); // 直接使用算法
for (const auto& x : arr) { /* 范围 for 循环 */ }

虽然原生数组也能用 std::begin 和 std::end,但 std::array 的接口更自然统一,尤其在模板编程中表现更好。

4. 内存布局与性能

std::array 在内存布局上与原生数组完全一致——所有元素连续存储,不带额外开销。它只是一个封装,编译器通常能完全优化掉这层包装。

这意味着:

  • std::array 不会在堆上分配内存
  • 访问速度与原生数组相同
  • 可以像原生数组一样用于 C 接口(通过 &arr[0] 或 arr.data())

基本上就这些。std::array 保留了原生数组的高效性,同时提供了更好的类型安全、尺寸访问、拷贝能力和 STL 兼容性。在现代 C++ 中,应优先使用 std::array 替代原生定长数组,除非有特殊限制。两者本质相似,但 std::array 更安全、更易用。