std::ranges:: borrowed_range, std::ranges:: enable_borrowed_range
|
ヘッダーで定義
<ranges>
|
||
|
template
<
class
R
>
concept borrowed_range
=
|
(1) | (C++20以降) |
|
template
<
class
R
>
constexpr bool enable_borrowed_range = false ; |
(2) | (C++20以降) |
borrowed_range
コンセプトは、関数が値を渡して範囲を受け取り、その範囲から取得したイテレータをダングリングの危険なく返すことができる要件を定義します。
enable_borrowed_range
変数テンプレートは、
range
が
borrowed_range
であるかどうかを示すために使用されます。プライマリテンプレートは
false
として定義されています。
目次 |
セマンティック要件
T
が右辺値参照型の場合、
U
を
std::
remove_reference_t
<
T
>
とし、それ以外の場合
U
を
T
とする。型
U
の変数
u
が与えられたとき、
T
が
borrowed_range
をモデルするのは、
u
から取得したイテレータの有効性がその変数の生存期間に依存しない場合に限る。
特殊化
プログラムは、cv修飾されていない
プログラム定義型
のうち
borrowed_range
をモデルとする型に対して
enable_borrowed_range
を
true
に特殊化でき、そうでない型に対しては
false
に特殊化できます。このような特殊化は
定数式
で使用可能であり、型は
const
bool
でなければなりません。
標準ライブラリにおける無条件借用レンジ
以下の標準テンプレートのすべての特殊化に対する
enable_borrowed_range
の特殊化は
true
として定義されます:
- std::basic_string_view
- std::span
- std::ranges::subrange
- std::ranges::ref_view
- std::ranges::empty_view
- std::ranges::iota_view
標準ライブラリにおける条件付き借用範囲
以下の標準範囲アダプタに対する
enable_borrowed_range
の特殊化は、
true
と定義されるのは、
std
::
ranges
::
enable_borrowed_range
<
V
>
が
true
である場合に限ります。ここで
V
は基盤となるビューの型です:
| (C++23以降) |
- std::ranges::common_view
- std::ranges::drop_view
- std::ranges::drop_while_view
- std::ranges::elements_view
| (C++23以降) |
/
タグ内のC++用語は翻訳せず、元のフォーマットを保持しています)
| (C++23以降) |
| (C++26以降) |
-
↑
基となるビュー
Vはforward_rangeも満たさなければならない。
|
以下の標準範囲アダプタに対する
|
(C++23以降) |
例
プログラム定義型に対する
enable_borrowed_range
の特殊化を示します。このような特殊化は、潜在的にダングリングする結果から保護します。
#include <algorithm> #include <array> #include <cstddef> #include <iostream> #include <ranges> #include <span> #include <type_traits> template<typename T, std::size_t N> struct MyRange : std::array<T, N> {}; template<typename T, std::size_t N> constexpr bool std::ranges::enable_borrowed_range<MyRange<T, N>> = false; template<typename T, std::size_t N> struct MyBorrowedRange : std::span<T, N> {}; template<typename T, std::size_t N> constexpr bool std::ranges::enable_borrowed_range<MyBorrowedRange<T, N>> = true; int main() { static_assert(std::ranges::range<MyRange<int, 8>>); static_assert(std::ranges::borrowed_range<MyRange<int, 8>> == false); static_assert(std::ranges::range<MyBorrowedRange<int, 8>>); static_assert(std::ranges::borrowed_range<MyBorrowedRange<int, 8>> == true); auto getMyRangeByValue = []{ return MyRange<int, 4>{{1, 2, 42, 3}}; }; auto dangling_iter = std::ranges::max_element(getMyRangeByValue()); static_assert(std::is_same_v<std::ranges::dangling, decltype(dangling_iter)>); // *dangling_iter; // コンパイルエラー(ダングリング保護が機能) auto my = MyRange<int, 4>{{1, 2, 42, 3}}; auto valid_iter = std::ranges::max_element(my); std::cout << *valid_iter << ' '; // OK: 42 auto getMyBorrowedRangeByValue = [] { static int sa[4]{1, 2, 42, 3}; return MyBorrowedRange<int, std::size(sa)>{sa}; }; auto valid_iter2 = std::ranges::max_element(getMyBorrowedRangeByValue()); std::cout << *valid_iter2 << '\n'; // OK: 42 }
出力:
42 42
関連項目
|
(C++20)
|
イテレータまたは
subrange
がダングリング状態になるため返すべきではないことを示すプレースホルダ型
(クラス) |