C++ 容器类 array
- C++11 标准引入了 头文件,它提供了一种固定大小的数组容器
- 与 C 语言中的数组相比,具有更好的类型安全和内存管理特性
- std::array 是 C++ 标准库中的一个模板类,它定义在 头文件中
- std::array 模板类提供了一个固定大小的数组,其大小在编译时确定,并且不允许动态改变
特点
类型安全
:std::array 强制类型检查,避免了 C 语言数组的类型不安全问题。固定大小
:数组的大小在编译时确定,不能在运行时改变。内存连续
:std::array 的元素在内存中是连续存储的,这使得它可以高效地访问元素。标准容器
:std::array 提供了与 std::vector 类似的接口,如 size(), at(), front(), back() 等。
常见的成员函数
函数 | 说明 |
---|
at(size_t pos) | 返回指定位置的元素,带边界检查 |
operator[] | 返回指定位置的元素,不带边界检查 |
front() | 返回数组的第一个元素 |
back() | 返回数组的最后一个元素 |
data() | 返回指向数组数据的指针 |
size() | 返回数组大小(固定不变) |
fill(const T& value) | 将数组所有元素设置为指定值 |
swap(array& other) | 交换两个数组的内容 |
begin() / end() | 返回数组的起始/结束迭代器 |
与其他数组类型对比
特性 | std::array | C 风格数组 | std::vector |
---|
大小 | 编译时固定 | 编译时固定 | 动态可变 |
边界检查 | at() 提供边界检查 | 无 | at() 提供边界检查 |
内存管理 | 栈上分配 | 栈上分配 | 堆上分配 |
性能 | 高效 | 高效 | 较低(动态分配) |
接口 | 支持 STL 标准接口 | 不支持 STL 标准接口 | 支持 STL 标准接口 |
应用场景
- 固定大小数组:需要固定大小的数组,如存储传感器数据。
- 嵌入式系统:内存受限的嵌入式系统,如微控制器中的数据存储。
- 静态数据:存储静态数据,如常量表或查找表。
- 多维数组:实现多维数组,如矩阵运算。
- 性能关键:需要高性能的场景,如实时系统中的数据处理。
底层
- 底层数据结构:静态数组
- 静态数组的介绍,增删查改的时间复杂度和空间复杂度分别是:
- 插入:时间复杂度为 O(1),空间复杂度为 O(n)
- 删除:时间复杂度为 O(1),空间复杂度为 O(n)
- 访问:时间复杂度为 O(1),空间复杂度为 O(n)
- 修改:时间复杂度为 O(1),空间复杂度为 O(n)
代码示例-01
#include <iostream>
#include <array>
int main() {
std::array<int, 5> myArray = {1, 2, 3, 4, 5};
for (const auto& value : myArray) {
std::cout << value << " ";
}
std::cout << std::endl;
std::cout << "Element at index 2: " << myArray.at(2) << std::endl;
std::cout << "Array size: " << myArray.size() << std::endl;
myArray[3] = 10;
for (const auto& value : myArray) {
std::cout << value << " ";
}
std::cout << std::endl;
return 0;
}
代码示例-02 (基本操作)
#include <iostream>
#include <array>
int main() {
std::array<int, 5> arr = {10, 20, 30, 40, 50};
std::cout << "Array elements: ";
for (int i = 0; i < arr.size(); ++i) {
std::cout << arr[i] << " ";
}
std::cout << std::endl;
std::cout << "First element: " << arr.front() << std::endl;
std::cout << "Last element: " << arr.back() << std::endl;
return 0;
}
代码示例-03 (使用at和边界检查)
#include <iostream>
#include <array>
int main() {
std::array<int, 3> arr = {1, 2, 3};
try {
std::cout << arr.at(2) << std::endl;
std::cout << arr.at(5) << std::endl;
} catch (const std::out_of_range& e) {
std::cout << "Exception: " << e.what() << std::endl;
}
return 0;
}
代码示例-04 (使用fill填充元素)
#include <iostream>
#include <array>
int main() {
std::array<int, 5> arr;
arr.fill(100);
std::cout << "Filled array: ";
for (const auto& elem : arr) {
std::cout << elem << " ";
}
std::cout << std::endl;
return 0;
}
代码示例-05 (数组交换)
#include <iostream>
#include <array>
int main() {
std::array<int, 3> arr1 = {1, 2, 3};
std::array<int, 3> arr2 = {4, 5, 6};
arr1.swap(arr2);
std::cout << "Array 1: ";
for (const auto& elem : arr1) {
std::cout << elem << " ";
}
std::cout << std::endl;
std::cout << "Array 2: ";
for (const auto& elem : arr2) {
std::cout << elem << " ";
}
std::cout << std::endl;
return 0;
}