Skip to content

Latest commit

 

History

History
84 lines (67 loc) · 3.14 KB

cbegin.md

File metadata and controls

84 lines (67 loc) · 3.14 KB

cbegin

  • 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の型を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;
  });
}
  • 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]

関連項目

参照