std::
deque::operator[]
公众成员函数 <deque>
reference operator[] (size_type n);
const_reference operator[] (size_type n) const;
访问元素
返回对deque容器中位置为n的元素的引用。
类似的成员函数deque::at与此操作符函数具有相同的行为,
不同的是deque::at会进行边界检查,如果请求的位置超出范围,
则抛出out_of_range异常发出信号。
☲ 参数
-
n
-
元素在容器中的位置。
注意第一个元素的位置是0(不是1)。
成员类型size_type是一个无符号整型。
☉ 返回值
在容器中指定位置的元素。
成员类型reference和const_reference是对容器元素的引用类型(参见deque成员类型)。
☣ 示例
// 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;
}
|
输出:
mydeque contains: 9 8 7 6 5 4 3 2 1 0
✥ 复杂度
常量
☣ 迭代器的有效性
不变
⇄ 数据竞争
容器被访问(const和非const版本都不会修改容器)。
元素n可能被访问或修改。并发访问或修改其他元素是安全的。
☂ 异常安全性
如果容器的大小大于n,函数永远不会抛出异常(no-throw保证)。
否则,行为是未定义的(可能包括抛出)。
🍄 另请参阅
deque::at |
访问元素(公众成员函数) |
deque::front |
访问首元素 (公众成员函数) |
deque::back |
访问最后一个元素(公众成员函数) |