std::begin, std::cbegin

来自cppreference.com
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
迭代器原语
算法概念与工具
间接可调用概念
常用算法要求
工具
迭代器适配器
流迭代器
迭代器定制点
迭代器操作
(C++11)
(C++11)
范围访问
begincbegin
(C++11)(C++14)
(C++11)(C++14)
(C++17)(C++20)
(C++14)(C++14)
(C++14)(C++14)
(C++17)
(C++17)
 
在标头 <array> 定义
在标头 <deque> 定义
在标头 <forward_list> 定义
在标头 <iterator> 定义
在标头 <list> 定义
在标头 <map> 定义
在标头 <regex> 定义
在标头 <set> 定义
在标头 <span> 定义
(C++20 起)
在标头 <string> 定义
在标头 <string_view> 定义
(C++17 起)
在标头 <unordered_map> 定义
在标头 <unordered_set> 定义
在标头 <vector> 定义
(1)
template< class C >
auto begin( C& c ) -> decltype(c.begin());
(C++11 起)
(C++17 前)
template< class C >
constexpr auto begin( C& c ) -> decltype(c.begin());
(C++17 起)
(1)
template< class C >
auto begin( const C& c ) -> decltype(c.begin());
(C++11 起)
(C++17 前)
template< class C >
constexpr auto begin( const C& c ) -> decltype(c.begin());
(C++17 起)
(2)
template< class T, std::size_t N >
T* begin( T (&array)[N] );
(C++11 起)
(C++14 前)
template< class T, std::size_t N >
constexpr T* begin( T (&array)[N] ) noexcept;
(C++14 起)
template< class C >

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

    -> decltype(std::begin(c));
(3) (C++14 起)

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

1) 准确返回 c.begin() ,典型地是指向 c 所代表的序列起始的迭代器。若 C 是标准容器 (Container) ,则在 c 不是 const 限定时返回 C::iterator ,否则返回 C::const_iterator
2) 返回指向 array 起始的指针。
3) 准确返回 std::begin(c) ,这里 c 始终被视为 const 限定。若 C 是标准容器 (Container) ,则始终返回 C::const_iterator

range-begin-end.svg

参数

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

返回值

指向范围起始的迭代器

异常

3)
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;
    }
}

实参依赖查找所找到的 begin 重载能用于定制 std::ranges::beginstd::ranges::cbegin 及其他依赖于 std::ranges::begin 的定制点对象的行为。

(C++20 起)

注解

(1,3) 准确地反映 C::begin() 的行为。若该成员函数无合理的实现,则它们的效果可能令人惊异。

std::cbegin 是为统一成员与非成员范围访问引入的。参阅 LWG 问题 2128

C 是浅 const 的视图,则 std::cbegin 可能返回可变的迭代器。某些用户不期待这种行为。参阅 P2276P2278

示例

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

输出:

3
-5

参阅

(C++11)(C++14)
返回指向容器或数组结尾的迭代器
(函数模板)
返回指向范围起始的迭代器
(定制点对象)
返回指向只读范围起始的迭代器
(定制点对象)