std::ranges:: crbegin
|
定義先ヘッダ
<ranges>
|
||
|
定義先ヘッダ
<iterator>
|
||
|
inline
namespace
/* unspecified */
{
inline
constexpr
/* unspecified */
crbegin
=
/* unspecified */
;
|
(C++20以降)
(カスタマイゼーションポイントオブジェクト) |
|
|
呼び出しシグネチャ
|
||
|
template
<
class
T
>
requires
/* see below */
|
(C++20以降) | |
|
引数を逆順シーケンスとして扱った場合の最初の要素を指すイテレータを返す(const修飾された引数に対して)。 |
(until C++23) |
|
引数を逆順シーケンスとして扱った場合の最初の要素を指すconstイテレータを返す。 |
(since C++23) |
|
|
(C++23以前) |
|
引数が左辺値、または
ranges::
enable_borrowed_range
<
std::
remove_cv_t
<
T
>>
が
true
の場合、
それ以外の場合、
|
(C++23以降) |
戻り値の型はすべての場合において
std::input_or_output_iterator
および
constant-iterator
(C++23以降)
をモデル化します。
カスタマイゼーションポイントオブジェクト
名前
ranges::crbegin
は
カスタマイゼーションポイントオブジェクト
を表し、これは
関数オブジェクト
のconst版で、
リテラル型
semiregular
クラス型である。詳細は
CustomizationPointObject
を参照。
例
#include <cassert> #include <iterator> #include <span> #include <vector> int main() { std::vector<int> v{3, 1, 4}; auto vi = std::ranges::crbegin(v); assert(*vi == 4); ++vi; // OK: イテレータオブジェクトは変更可能 assert(*vi == 1); // *vi = 13; // エラー: 基底要素は読み取り専用 int a[]{-5, 10, 15}; auto ai = std::ranges::crbegin(a); assert(*ai == 15); // auto x_x = std::ranges::crbegin(std::vector<int>{6, 6, 6}); // 不正な形式: 引数が右辺値です(注記↑参照) auto si = std::ranges::crbegin(std::span{a}); // OK assert(*si == 15); static_assert ( std::ranges::enable_borrowed_range<std::remove_cv_t<decltype(std::span{a})>> ); }
関連項目
|
(C++20)
|
範囲の逆方向イテレータを返す
(カスタマイゼーションポイントオブジェクト) |
|
(C++14)
|
コンテナまたは配列の先頭への逆方向イテレータを返す
(関数テンプレート) |