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

履歴 編集

class template
<ranges>

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

namespace std {
  namespace ranges {
    template<view V>
    requires (!common_range<V> && copyable<iterator_t<V>>)
    class common_view : public view_interface<common_view<V>> { …… }; // (1)

    namespace views {
      inline constexpr /*unspecified*/ common = /*unspecified*/;     // (2)
    }
  }

  namespace views = ranges::views;
}

概要

  • (1): 任意のRangeをcommon_rangeにするview
  • (2): common_viewまたは同じ効果を実現するviewを生成するRangeアダプタオブジェクト

同じ型のイテレータペアを受け取るレガシーなアルゴリズム関数に対して、common_rangeではない範囲を渡したい場合、commonを使用することで同じ型のイテレータペアを取得できるようになる。

Rangeコンセプト

borrowed sized output input forward bidirectional random_access contiguous common viewable view

※ 参照先のRangeに従う

テンプレートパラメータ制約

効果

  • (2): 式views::common(E)の効果は次の通り

メンバ関数

名前 説明 対応バージョン
(constructor) コンストラクタ C++20
base Rの参照を取得する C++20
begin 先頭を指すイテレータを取得する C++20
end 番兵を取得する C++20
size 要素数を取得する C++20

rを参照先のRangeとする。sizeは、ranges::size(r)が有効な式であるときに定義される。

継承しているメンバ関数

名前 説明 対応バージョン
empty Rangeが空かどうかを判定する C++20
operator bool Rangeが空でないかどうかを判定する C++20
data Rangeの先頭へのポインタを取得する C++20
front 先頭要素への参照を取得する C++20
back 末尾要素への参照を取得する C++20
operator[] 要素へアクセスする C++20

推論補助

名前 説明 対応バージョン
(deduction_guide) クラステンプレートの推論補助 C++20

#include <ranges>
#include <concepts>
#include <string_view>

int main() {
  using namespace std;

  // 無限長のiotaはcommon_rangeではない
  static_assert(!ranges::common_range<decltype(views::iota(0))>);
  // commonを適用するとcommon_rangeになる
  static_assert(ranges::common_range<decltype(views::iota(0) | views::common)>);

  // 元からcommon_rangeなviewに適用しても型は変わらない
  static_assert(same_as<decltype(string_view{} | views::common), string_view>);
}

出力

バージョン

言語

  • C++20

処理系

関連項目

参照