Scroll to navigation

std::ranges::cbegin(3) C++ Standard Libary std::ranges::cbegin(3)

NAME

std::ranges::cbegin - std::ranges::cbegin

Synopsis


Defined in header <ranges>
Defined in header <iterator>
inline namespace /* unspecified */ {


inline constexpr /* unspecified */ cbegin = /* (since C++20)
unspecified */; (customization point object)


}
Call signature
template< class T >


requires /* see below */ (since C++20)


constexpr /* see below */ auto cbegin( T&& t );


Returns an iterator to the first element of the const-qualified (until C++23)
argument.
Returns a constant iterator to the first element of the argument. (since C++23)


range-begin-end.svg


Let CT be


* const std::remove_reference_t<T>& if the argument is an lvalue (i.e. T is
an lvalue reference type), (until
* const T otherwise. C++23)


A call to ranges::cbegin is expression-equivalent to
ranges::begin(static_cast<CT&&>(t)).
If the argument is an lvalue or
ranges::enable_borrowed_range<std::remove_cv_t<T>> is true, then a call to
ranges::cbegin is expression-equivalent to:


* std::const_iterator<decltype(U)>(U) for some expression U equivalent to (since
ranges::begin(/*possibly-const-range*/(t)). C++23)


In all other cases, a call to ranges::cbegin is ill-formed, which can result
in substitution failure when the call appears in the immediate context of a
template instantiation.


The return type models std::input_or_output_iterator
and constant-iterator
(since C++23) in all cases.

Notes


For an lvalue range e of type T, ranges::cbegin(e) is equivalent to


ranges::begin(std::as_const(e)). (until C++23)
* ranges::begin(e) if T models constant_range.
* Otherwise, ranges::begin(std::as_const(e)) if const T models (since C++23)
constant_range.
* Otherwise, std::basic_const_iterator(ranges::begin(e)).

Example

// Run this code


#include <cassert>
#include <ranges>
#include <vector>


int main()
{
std::vector v{3, 1, 4};
auto vi = std::ranges::cbegin(v);
assert(3 == *vi);
++vi; // OK, constant-iterator object is mutable
assert(1 == *vi);
// *vi = 13; // Error: constant-iterator points to an immutable element


int a[]{3, 1, 4};
auto ai = std::ranges::cbegin(a); // cbegin works with C-arrays as well
assert(3 == *ai and *(ai + 1) == 1);
// *ai = 13; // Error: read-only variable is not assignable
}

See also


ranges::begin returns an iterator to the beginning of a range
(C++20) (customization point object)
begin
cbegin returns an iterator to the beginning of a container or array
(C++11) (function template)
(C++14)

2024.06.10 http://cppreference.com