std::ranges:: views:: common, std::ranges:: common_view
|
ヘッダーで定義
<ranges>
|
||
|
template
<
ranges::
view
V
>
requires
(
not
ranges::
common_range
<
V
>
and
|
(1) | (C++20以降) |
|
namespace
views
{
inline
constexpr
/* 未規定 */
common
=
/* 未規定 */
;
|
(2) | (C++20以降) |
|
呼び出しシグネチャ
|
||
|
template
<
ranges::
viewable_range
R
>
requires
/* 下記参照 */
|
(C++20以降) | |
view
を、イテレータ/番兵ペアの異なる型から、
view
でありながら
common_range
でもあるものに適合させます。
common_view
は常に同じイテレータ/番兵型を持ちます。
-
views::
all
(
e
)
が有効な式であり、かつ
decltype
(
(
e
)
)
が
common_rangeをモデルとする場合; - それ以外の場合、 common_view { e } 。
目次 |
データメンバ
| メンバー | 説明 |
V
base_
(private)
|
基となるビュー
( 説明専用メンバーオブジェクト* ) |
メンバー関数
common_view
を構築する
(公開メンバ関数) |
|
|
基盤となる(アダプトされた)ビューのコピーを返す
(公開メンバ関数) |
|
|
先頭へのイテレータを返す
(公開メンバ関数) |
|
|
終端へのイテレータを返す
(公開メンバ関数) |
|
要素数を返す(基盤となる(アダプトされた)範囲が
sized_range
を満たす場合にのみ提供)
(公開メンバ関数) |
|
|
(C++26)
|
結果の
approximately_sized_range
の近似サイズを返す
(公開メンバ関数) |
std::ranges::view_interface から継承 |
|
派生ビューが空かどうかを返す(
sized_range
または
forward_range
を満たす場合にのみ提供)
(
std::ranges::view_interface<D>
の公開メンバ関数)
|
|
|
(C++23)
|
範囲の先頭への定数イテレータを返す
(
std::ranges::view_interface<D>
の公開メンバ関数)
|
|
(C++23)
|
範囲の定数イテレータの番兵を返す
(
std::ranges::view_interface<D>
の公開メンバ関数)
|
|
派生ビューが空でないかどうかを返す(
ranges::empty
が適用可能な場合にのみ提供)
(
std::ranges::view_interface<D>
の公開メンバ関数)
|
|
派生ビューのデータのアドレスを取得する(そのイテレータ型が
contiguous_iterator
を満たす場合にのみ提供)
(
std::ranges::view_interface<D>
の公開メンバ関数)
|
|
派生ビューの最初の要素を返す(
forward_range
を満たす場合に提供)
(
std::ranges::view_interface<D>
の公開メンバ関数)
|
|
派生ビューの最後の要素を返す(
bidirectional_range
かつ
common_range
を満たす場合にのみ提供)
(
std::ranges::view_interface<D>
の公開メンバ関数)
|
|
派生ビューの
n
th
番目の要素を返す(
random_access_range
を満たす場合にのみ提供)
(
std::ranges::view_interface<D>
の公開メンバ関数)
|
|
推論ガイド
ヘルパーテンプレート
|
template
<
class
T
>
constexpr
bool
enable_borrowed_range
<
std
::
ranges
::
common_view
<
T
>>
=
|
(C++20以降) | |
この
ranges::enable_borrowed_range
の特殊化は、基となるビューが
borrowed_range
を満たす場合に、
common_view
がそれを満たすようにする。
注記
common_view
は、イテレータと番兵が同じ型であることを期待するレガシーアルゴリズムを扱う際に有用です。
例
#include <initializer_list> #include <iostream> #include <iterator> #include <list> #include <numeric> #include <ranges> int main() { auto v1 = {1, 2, 3, 4, 5}; auto i1 = std::counted_iterator{v1.begin(), std::ssize(v1)}; auto r1 = std::ranges::subrange{i1, std::default_sentinel}; // auto e1 = std::accumulate(r1.begin(), r1.end(), 0); // エラー: "common range" が必要 auto c1 = std::ranges::common_view{r1}; std::cout << "accumulate: " << std::accumulate(c1.begin(), c1.end(), 0) << '\n'; // ranges::view_interface から継承: std::cout << "c1.front(): " << c1.front() << '\n'; std::cout << "c1.back(): " << c1.back() << '\n'; std::cout << "c1.data(): " << c1.data() << '\n'; std::cout << "c1[0]: " << c1[0] << '\n'; auto v2 = std::list{1, 2, 3, 4, 5}; auto i2 = std::counted_iterator{v2.begin(), std::ssize(v2)}; auto r2 = std::ranges::subrange{i2, std::default_sentinel}; // auto e2 = std::accumulate(r2.begin(), r2.end(), 0); // エラー: "common range" が必要 auto c2 = std::ranges::common_view{ r2 }; std::cout << "accumulate: " << std::accumulate(c2.begin(), c2.end(), 0) << '\n'; // ranges::view_interface から継承: std::cout << "c2.front(): " << c2.front() << '\n'; // auto e3 = c2.back(); // エラー: "bidirectional range" が必要 // auto e4 = c2.data(); // エラー: "contiguous range" が必要 // auto e5 = c2[0]; // エラー: "random access range" が必要 }
出力例:
accumulate: 15 c1.front(): 1 c1.back(): 5 c1.data(): 0x7f19937f00d0 c1[0]: 1 accumulate: 15 c2.front(): 1
不具合報告
以下の動作変更の欠陥報告書は、以前に公開されたC++規格に対して遡及的に適用されました。
| DR | 適用対象 | 公開時の動作 | 正しい動作 |
|---|---|---|---|
| LWG 3494 | C++20 |
common_view
は決して
borrowed_range
ではなかった
|
基盤となるビューが
borrowed_range
である場合、それも
borrowed_range
となる
|
関連項目
|
(C++20)
|
範囲が同一のイテレータ型とセンチネル型を持つことを指定する
(コンセプト) |
|
(C++20)
|
イテレータ型とそのセンチネルを共通のイテレータ型に適合させる
(クラステンプレート) |