C++官网参考链接:https://cplusplus.com/reference/deque/deque/operator[]/
公有成员函数
<deque>
std::deque::operator[]
reference operator[] (size_type n);
const_reference operator[] (size_type n) const;
访问元素
返回deque容器中位置n的元素的reference。
类似的成员函数deque::at具有与该操作符函数相同的行为,不同的是deque::at是绑定检查的,如果请求的位置超出了范围,则抛出out_of_range异常发出信号。
形参
n
元素在容器中的位置。
注意,第一个元素的位置为0(而不是1)。
成员类型size_type是无符号整型。
返回值
位于容器中指定位置的元素。
成员类型reference和const_reference是容器元素的reference类型(参见deque成员类型(deque member types))。
用例
// deque::operator[] example: reversing order
#include <iostream>
#include <deque>
int main ()
{
std::deque<int> mydeque (10); // 10 zero-initialized elements
std::deque<int>::size_type sz = mydeque.size();
// assign some values:
for (unsigned i=0; i<sz; i++) mydeque[i]=i;
// reverse order of elements using operator[]:
for (unsigned i=0; i<sz/2; i++)
{
int temp;
temp = mydeque[sz-1-i];
mydeque[sz-1-i]=mydeque[i];
mydeque[i]=temp;
}
// print content:
std::cout << "mydeque contains:";
for (unsigned i=0; i<sz; i++)
std::cout << ' ' << mydeque[i];
std::cout << '\n';
return 0;
}
输出:
复杂度
常量。
iterator的有效性
没有变化。
数据竞争
容器被访问(const和非const版本都不会修改容器)。
元素n可能被访问或修改。同时访问或修改其他元素是安全的。
异常安全
如果容器的size大于n,则该函数永远不会抛出异常(无抛出保证)。
否则,该行为是未定义的(可能包括抛出)。