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

履歴 編集

customization point object
<ranges>

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

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

概要

Rangeから先頭要素への読み取り専用イテレータを取得する関数オブジェクト。

効果

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

戻り値

先頭要素への読み取り専用イテレータ。

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

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

備考

ranges::cbeginの呼び出しが有効な式であるとき、その型はinput_or_output_iteratorのモデルであり、C++23以降はさらにconstant-iteratorのモデルである。

C++20まではrangeRbegin()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;
  });
}

出力

1
2
3

バージョン

言語

  • C++20

処理系

関連項目

参照