std::Array 是 c++++11 引入的固定大小容器,定义在
在c++11中,std::array 容器的引入让数组操作变得更加清晰、安全,同时也保留了传统数组的性能优势。相比起我们以前用的原生数组,它不仅提供了更好的封装性,还能和STL的算法更好地配合使用。
std::array 是什么?
std::array 是一个固定大小的容器,定义在
- 支持迭代器访问
- 可以直接赋值(拷贝)
- 有 .size() 方法获取元素个数
- 和 STL 算法兼容更好
声明方式如下:
立即学习“C++免费学习笔记(深入)”;
#include <array> std::array<int, 5> arr = {1, 2, 3, 4, 5};
这个写法比传统的 int arr[5] = {1, 2, 3, 4, 5}; 更明确,也更容易传递给函数。
和传统数组相比有哪些优势?
-
可以直接赋值
原生数组不能直接赋值,必须手动拷贝。而 std::array 可以直接用 = 操作符进行复制。std::array<int, 3> a1 = {1, 2, 3}; std::array<int, 3> 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() 获取原始指针后做越界访问,这仍然可能导致未定义行为。
基本上就这些。用起来不复杂,但确实能减少很多麻烦。