- ranges[meta header]
- std::ranges[meta namespace]
- cpo[meta id-type]
- cpp20[meta cpp]
namespace std::ranges {
inline namespace /*unspecified*/ {
inline constexpr /*unspecified*/ begin = /*unspecified*/;
}
}
Rangeから先頭要素へのイテレータを取得する関数オブジェクト。
部分式E
の型をT
、t
をE
を評価した値とする。
このとき、式ranges::begin(E)
の効果は以下の通り。
E
がrvalueかつenable_borrowed_range
<
remove_cv_t
<T>>
がfalse
であれば、呼び出しは不適格。T
が配列型であれば、t + 0
に等しい(expression‑equivalent)。ただし、remove_all_extents_t
<T>
が不完全型であれば、呼び出しは不適格(診断不要)。decay-copy
(t.begin())
が有効な式でその型がinput_or_output_iterator
のモデルであれば、decay-copy
(t.begin())
と等しい。T
がクラス型または列挙体であって、begin
がADLで見つかり、decay-copy
(begin(t))
が有効な式でその型がinput_or_output_iterator
のモデルであれば、decay-copy
(begin(t))
と等しい。
どれにも当てはまらないとき、呼び出しは不適格。
Rangeの先頭要素へのイテレータ。
3か4の条件を満たすようにする。例えば、ユーザー定義のフリー関数begin
を定義するか、ユーザー定義のクラスにメンバ関数begin
を持たせることでカスタマイズできる。
ranges::begin
の呼び出しが有効な式であるとき、その型はinput_or_output_iterator
のモデルである。
#include <iostream>
#include <vector>
#include <ranges>
#include <algorithm>
void print(int x)
{
std::cout << x << " ";
}
int main()
{
// コンテナ
{
std::vector<int> v = {1, 2, 3};
decltype(v)::iterator first = std::ranges::begin(v);
decltype(v)::iterator last = std::ranges::end(v);
std::for_each(first, last, print);
}
std::cout << std::endl;
// 組み込み配列
{
int ar[] = {4, 5, 6};
int* first = std::ranges::begin(ar);
int* last = std::ranges::end(ar);
std::for_each(first, last, print);
}
}
- std::ranges::begin[color ff0000]
- std::ranges::end[link end.md]
1 2 3
4 5 6
- C++20
- Clang: 13.0.0 [mark verified]
- GCC: 10.1.0 [mark verified]
- ICC: ?
- Visual C++: 2019 Update 10 [mark verified]