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

std::

deque::at

公众成员函数  <deque>
      reference at (size_type n);
const_reference at (size_type n) const;
访问元素

返回对deque容器中位置为n的元素的引用。

函数自动检查n是否在容器中有效元素的范围内,如果不在范围内(即n大于或等于其大小), 则抛出out_of_range异常。这与不检查边界的成员操作符[]形成了对比。

这个成员函数和成员操作符operator[]的区别在于,如果请求的位置超出范围, deque::at会抛出一个out_of_range异常。

☲  参数


n
元素在容器中的位置。
如果这个值大于deque容器的大小,则抛出out_of_range类型的异常。
注意第一个元素的位置是0(不是1)。
成员类型size_type是一个无符号整型。

☉  返回值



在容器中指定位置的元素。
如果deque对象是const限定的,则函数返回一个const_reference。否则,它返回一个引用。
成员类型reference和const_reference是对容器元素的引用类型(参见deque成员类型)。

☣  示例



// deque::at
#include <iostream>
#include <deque>

int main ()
{
  std::deque<unsigned> mydeque (10);   // 10 zero-initialized unsigneds

  // assign some values:
  for (unsigned i=0; i<mydeque.size(); i++)
    mydeque.at(i)=i;

  std::cout << "mydeque contains:";
  for (unsigned i=0; i<mydeque.size(); i++)
    std::cout << ' ' << mydeque.at(i);

  std::cout << '\n';

  return 0;
}

输出:
mydeque contains: 0 1 2 3 4 5 6 7 8 9

✥ 复杂度



常量

☣ 迭代器的有效性



不变

⇄ 数据竞争


容器被访问(const和非const版本都不会修改容器)。
元素n可能被访问或修改。并发访问或修改其他元素是安全的。

☂ 异常安全性



强保证:如果抛出异常,容器中没有任何变化。
如果n是越界的,它抛出out_of_range。

🍄  另请参阅



deque::operator[] 访问元素(公众成员函数)
deque::front 访问首元素 (公众成员函数)
deque::back 访问最后一个元素(公众成员函数)

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