C++学习笔记--STL标准模板库的认识与使用--序列式容器--array(数组)--(C++11)

1、什么是array?

std::array 是 STL 提供的 内存连续的固定长度 的数组数据结构。其本质是对原生数组的直接封装。

2、为什么要用 array?

array 实际上是 STL 对数组的封装。它相比 vector 牺牲了动态扩容的特性,但是换来了与原生数组几乎一致的性能(在开满优化的前提下)。因此如果能使用 C++11 特性的情况下,能够使用原生数组的地方几乎都可以直接把定长数组都换成 array,而动态分配的数组可以替换为 vector

3、成员函数

隐式定义的成员函数

函数 作用
operator= 以来自另一 array 的每个元素重写 array 的对应元素

4、元素访问

函数 作用
at 访问指定的元素,同时进行越界检查
operator[] 访问指定的元素, 进行越界检查
front 访问第一个元素
back 访问最后一个元素
data 返回指向内存中数组第一个元素的指针

at 若遇 pos >= size() 的情况会抛出 std::out_of_range

5、容量

函数 作用
empty 检查容器是否为空
size 返回容纳的元素数
max_size 返回可容纳的最大元素数

由于每个 array 都是固定大小容器,size() 返回的值等于 max_size() 返回的值。

6、操作

函数 作用
fill 以指定值填充容器
swap 交换内容

注意,交换两个 array 是  的,而非与常规 STL 容器一样为 。

7、非成员函数

函数 作用
operator== 等 按照字典序比较 array 中的值
std::get 访问 array 的一个元素
std::swap 特化的 std::swap 算法

8、下面是一个 array 的使用示例:

#include<iostream>

#include<array>

using namespace std;

int main()
{
	array<int,3> a;//长度为3,数组名a

	array<int, 3> b{ 1,2,3 };//长度为3,数组名b,初始化为1,2,3

	for (int i = 0; i != b.size(); ++i)//访问数组b
		cout << b[i] << ' ';

	cout << endl;

	a.fill(1);

	for (int i = 0; i != a.size(); ++i)//访问数组a
		cout << a[i] << ' ';

	return 0;
}

9、运行结果: 

 

おすすめ

転載: blog.csdn.net/qq_51701007/article/details/121252891