Home C&C++函数库 c++ 语法 程序源码 Linux C库

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 访问最后一个元素(公众成员函数)

联系我们 免责声明 关于CandCplus 网站地图