std::array 是 c++++11 引入的固定大小容器,定义在

在C++11中,std::array 容器的引入让数组操作变得更加清晰、安全,同时也保留了传统数组的性能优势。相比起我们以前用的原生数组,它不仅提供了更好的封装性,还能和STL的算法更好地配合使用。

std::array 是什么?
std::array 是一个固定大小的容器,定义在 头文件里。它本质上是对传统数组的封装,但增加了更多实用的功能。比如:
- 支持迭代器访问
- 可以直接赋值(拷贝)
- 有
.size()方法获取元素个数 - 和 STL 算法兼容更好
声明方式如下:
立即学习“C++免费学习笔记(深入)”;

#includestd::array arr = {1, 2, 3, 4, 5};
这个写法比传统的 int arr[5] = {1, 2, 3, 4, 5}; 更明确,也更容易传递给函数。
和传统数组相比有哪些优势?
-
可以直接赋值
原生数组不能直接赋值,必须手动拷贝。而std::array可以直接用=操作符进行复制。
std::array
a1 = {1, 2, 3}; std::array a2 = a1; // 合法 -
支持迭代器和范围 for 循环
这意味着你可以很方便地结合 STL 的算法来处理数据:for (auto& val : arr) { std::cout << val << " "; } -
更安全的边界检查(虽然默认不开启)
虽然std::array本身没有越界检查,但你可以配合.at()方法使用异常机制来增加安全性:try { arr.at(10); // 如果索引超出范围会抛出异常 } catch (...) { // 处理错误 } 可以作为函数参数传递整个数组
原生数组作为参数时会退化为指针,丢失大小信息。而std::array不会出现这个问题。
性能上差别大吗?
简单来说:几乎没有差别。std::array 在底层仍然是静态数组,不会产生额外的运行时开销。编译器对它的优化程度和原生数组几乎一样。所以你既获得了现代 C++ 的便利,又不用担心性能损耗。
如果你关注效率,可以放心使用。尤其是在嵌入式或性能敏感的场景中,std::array 是一个非常合适的替代品。
使用建议与注意事项
- 当你需要一个固定大小的数组,并希望它能很好地融入 STL 体系时,优先考虑
std::array。 - 如果你需要动态扩容,那应该选择
std::vector而不是std::array。 - 注意
std::array的大小是模板参数的一部分,也就是说std::array和std::array是两个完全不同的类型。 - 小心不要混用
.data()获取原始指针后做越界访问,这仍然可能导致未定义行为。
基本上就这些。用起来不复杂,但确实能减少很多麻烦。










