最終更新日時(UTC):
が更新

履歴 編集

customization point object
<ranges>

std::ranges::crbegin(C++20)

namespace std::ranges {
  inline namespace /*unspecified*/ {
    inline constexpr /*unspecified*/ crbegin = /*unspecified*/;
  }
}

概要

Rangeの末尾を指す読み取り専用逆イテレータを取得する関数オブジェクト。

効果

部分式Eの型をTEの評価結果オブジェクトを示す左辺値をtとする。このとき、式ranges::crbegin(E)の効果は以下の式と等しい。

戻り値

Rangeの末尾を指す読み取り専用逆イテレータ。

カスタマイゼーションポイント

Rangeがconstな場合についてranges::rbeginをカスタマイズすることで、ranges::crbeginをカスタマイズできる。

備考

ranges::crbeginの呼び出しが有効な式であるとき、その型はinput_or_output_iteratorのモデルであり、C++23以降はさらにconstant-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)::const_reverse_iterator first = std::ranges::crbegin(v);
    decltype(v)::const_reverse_iterator last = std::ranges::crend(v);

    std::for_each(first, last, print);
  }
  std::cout << std::endl;

  // 組み込み配列
  {
    int ar[] = {4, 5, 6};

    std::reverse_iterator<const int*> first = std::ranges::crbegin(ar);
    std::reverse_iterator<const int*> last = std::ranges::crend(ar);

    std::for_each(first, last, print);
  }
  std::cout << std::endl;

  // 初期化子リスト
  {
    std::initializer_list<int> init = {7, 8, 9};

    std::reverse_iterator<const int*> first = std::ranges::crbegin(init);
    std::reverse_iterator<const int*> last = std::ranges::crend(init);

    std::for_each(first, last, print);
  }
}

出力

3 2 1 
6 5 4 
9 8 7 

バージョン

言語

  • C++20

処理系

関連項目

参照