命名空间
变体
操作

std::begin, std::cbegin

来自 cppreference.cn
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
迭代器原语
算法概念和工具
间接可调用概念
通用算法要求
(C++20)
(C++20)
(C++20)
实用工具
(C++20)
迭代器适配器
范围访问
begincbegin
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
定义于头文件 <array>
定义于头文件 <deque>
定义于头文件 <flat_map>
定义于头文件 <flat_set>
定义于头文件 <forward_list>
定义于头文件 <inplace_vector>
定义于头文件 <iterator>
定义于头文件 <list>
定义于头文件 <map>
定义于头文件 <regex>
定义于头文件 <set>
定义于头文件 <span>
定义于头文件 <string>
定义于头文件 <string_view>
定义于头文件 <unordered_map>
定义于头文件 <unordered_set>
定义于头文件 <vector>
template< class C >
auto begin( C& c ) -> decltype(c.begin());
(1) (since C++11) (自 C++11 起)
(constexpr since C++17) (constexpr 自 C++17 起)
template< class C >
auto begin( const C& c ) -> decltype(c.begin());
(2) (since C++11) (自 C++11 起)
(constexpr since C++17) (constexpr 自 C++17 起)
template< class T, std::size_t N >
T* begin( T (&array)[N] );
(3) (since C++11) (自 C++11 起)
(noexcept since C++14) (noexcept 自 C++14 起)
(constexpr since C++14) (constexpr 自 C++14 起)
template< class C >

constexpr auto cbegin( const C& c ) noexcept(/* see below */)

    -> decltype(std::begin(c));
(4) (since C++14) (自 C++14 起)

返回给定范围的起始迭代器。

1,2) 返回 c.begin(),它通常是表示 c 的序列的起始迭代器。
1) 如果 C 是标准 容器 (Container),则返回 C::iterator 对象。
2) 如果 C 是标准 容器 (Container),则返回 C::const_iterator 对象。
3) 返回指向 array 开头的指针。
4) 返回 std::begin(c),其中 c 始终被视为 const 限定。
如果 C 是标准 容器 (Container),则返回 C::const_iterator 对象。

range-begin-end.svg

目录

[编辑] 参数

c - 具有 begin 成员函数的容器或视图
array - 任意类型的数组

[编辑] 返回值

1,2) c.begin()
3) array
4) c.begin()

[编辑] 异常

4)
noexcept 规范:  
noexcept(noexcept(std::begin(c)))

[编辑] 重载

可以为不公开合适的 begin() 成员函数但可以迭代的类和枚举提供 begin 的自定义重载。标准库已提供以下重载

重载 std::begin
(函数模板) [编辑]
重载 std::begin
(函数模板) [编辑]
基于范围的 for 循环支持
(函数) [编辑]
基于范围的 for 循环支持
(函数) [编辑]

类似于 swap 的用法(在 可交换 (Swappable) 中描述),在泛型上下文中 begin 函数的典型用法等效于 using std::begin; begin(arg);,这允许用户定义类型的 ADL 选择的重载和标准库函数模板出现在同一重载集中。

template<typename Container, typename Function>
void for_each(Container&& cont, Function f)
{
    using std::begin;
    auto it = begin(cont);
    using std::end;
    auto end_it = end(cont);
    while (it != end_it)
    {
        f(*it);
        ++it;
    }
}

通过实参依赖查找 (ADL) 找到的 begin 重载可用于自定义 std::ranges::beginstd::ranges::cbegin 和其他依赖于 std::ranges::begin 的自定义指针对象的行为。

(since C++20) (自 C++20 起)

[编辑] 注解

非数组重载完全反映了 C::begin 的行为。如果成员函数没有合理的实现,则其效果可能会令人惊讶。

引入 std::cbegin 是为了统一成员和非成员范围访问。另请参见 LWG issue 2128

如果 C 是浅层 const 视图,则 std::cbegin 可能会返回可变迭代器。对于某些用户来说,这种行为是出乎意料的。另请参见 P2276P2278

[编辑] 示例

#include <iostream>
#include <iterator>
#include <vector>
 
int main() 
{
    std::vector<int> v = {3, 1, 4};
    auto vi = std::begin(v);
    std::cout << std::showpos << *vi << '\n'; 
 
    int a[] = {-5, 10, 15};
    auto ai = std::begin(a);
    std::cout << *ai << '\n';
}

输出

+3
-5

[编辑] 参见

(C++11)(C++14)
返回容器或数组末尾的迭代器
(函数模板) [编辑]
返回范围开始的迭代器
(自定义点对象)[编辑]
返回只读范围开始的迭代器
(自定义点对象)[编辑]