public member function
<list>

std::list::end

      iterator end();const_iterator end() const;
      iterator end() noexcept;const_iterator end() const noexcept;
返回指向末尾的迭代器
返回指向list容器中“末尾之后”元素的迭代器。

末尾之后”元素是理论上位于list容器最后一个元素之后的元素。它不指向任何元素,因此不应被解引用。

由于标准库函数使用的范围不包括其结束迭代器所指向的元素,因此此函数通常与list::begin结合使用,以指定一个包含容器中所有元素的范围。

如果容器为空,则此函数返回的值与list::begin相同。

参数



返回值

指向序列末尾之后元素的迭代器。

如果 list 对象是 const-qualified,则函数返回一个const_iterator。否则,它返回一个iterator.

成员类型iteratorconst_iterator双向迭代器类型(分别指向一个元素和指向一个const元素)。

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// list::begin/end
#include <iostream>
#include <list>

int main ()
{
  int myints[] = {75,23,65,42,13};
  std::list<int> mylist (myints,myints+5);

  std::cout << "mylist contains:";
  for (std::list<int>::iterator it=mylist.begin() ; it != mylist.end(); ++it)
    std::cout << ' ' << *it;

  std::cout << '\n';

  return 0;
}

输出
mylist contains: 75 23 65 42 13


复杂度

常量。

迭代器有效性

没有变化。

数据竞争

访问容器(const 和非 const 版本都不会修改容器)。
调用该函数不访问任何包含的元素,但返回的迭代器可用于访问或修改元素。并发访问或修改不同元素是安全的。

异常安全

无异常保证:此成员函数从不抛出异常。
还可以保证返回的迭代器的复制构造或赋值永远不会引发异常。

另见