- ranges[meta header]
- std::ranges[meta namespace]
- cpo[meta id-type]
- cpp20[meta cpp]
namespace std::ranges {
inline namespace /*unspecified*/ {
inline constexpr /*unspecified*/ cbegin = /*unspecified*/;
}
}
Rangeから先頭要素への読み取り専用イテレータを取得する関数オブジェクト。
部分式E
の型をT
、E
の評価結果オブジェクトを示す左辺値をt
とする。このとき、式ranges::cbegin(E)
の効果は以下の式と等しい。
- C++20まで
E
がlvalueであれば、ranges::begin
(static_cast<const T&>(E))
- それ以外の場合、
ranges::begin
(static_cast<const T&&>(E))
- C++23から
E
が右辺値であり、enable_borrowed_range
<remove_cv_t<T>>
がfalse
となる場合、ranges::cbegin(E)
は不適格- それ以外の場合、式
U
をranges::begin
(
possibly-const-range
(t))
とすると、const_iterator
<decltype(U)>(U)
先頭要素への読み取り専用イテレータ。
Rangeがconst
な場合についてranges::begin
をカスタマイズすることで、ranges::cbegin
をカスタマイズできる。
ranges::cbegin
の呼び出しが有効な式であるとき、その型はinput_or_output_iterator
のモデルであり、C++23以降はさらにconstant-iterator
のモデルである。
C++20まではrange
型R
のbegin()
のconst
オーバーロードを呼び出してていたため得られたイテレータは必ずしも定数イテレータではない場合があったが、C++23からはそこから定数イテレータが得られない場合にbasic_const_iterator
を使用することで確実に定数イテレータを取得する。
#include <iostream>
#include <vector>
#include <ranges>
#include <algorithm>
int main()
{
std::vector<int> v = {1, 2, 3};
decltype(v)::const_iterator first = std::ranges::cbegin(v);
decltype(v)::const_iterator last = std::ranges::cend(v);
std::for_each(first, last, [](const int& x) {
std::cout << x << std::endl;
});
}
- std::ranges::cbegin[color ff0000]
- std::ranges::cend[link cend.md]
1
2
3
- C++20
- Clang: 13.0.0 [mark verified]
- GCC: 10.1.0 [mark verified]
- ICC: ?
- Visual C++: 2019 Update 10 [mark verified]