Namespaces
Variants

std::ranges:: borrowed_range, std::ranges:: enable_borrowed_range

From cppreference.net
Ranges library
Range adaptors
ヘッダーで定義 <ranges>
template < class R >

concept borrowed_range =
ranges:: range < R > &&
( std:: is_lvalue_reference_v < R > ||

ranges :: enable_borrowed_range < std:: remove_cvref_t < R >> ) ;
(1) (C++20以降)
template < class R >
constexpr bool enable_borrowed_range = false ;
(2) (C++20以降)
1) borrowed_range コンセプトは、関数が値を渡して範囲を受け取り、その範囲から取得したイテレータをダングリングの危険なく返すことができる要件を定義します。
2) 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 として定義されます:

標準ライブラリにおける条件付き借用範囲

以下の標準範囲アダプタに対する enable_borrowed_range の特殊化は、 true と定義されるのは、 std :: ranges :: enable_borrowed_range < V > true である場合に限ります。ここで V は基盤となるビューの型です:

(C++23以降)
(C++23以降)
(注:指示された通り、HTMLタグ・属性、 / タグ内のC++用語は翻訳せず、元のフォーマットを保持しています)
(C++23以降)
(C++26以降)
  1. 基となるビュー V forward_range も満たさなければならない。

以下の標準範囲アダプタに対する enable_borrowed_range の特殊化は、 true ( std :: ranges :: enable_borrowed_range < Vs > && ... ) true である場合に限り true として定義されます。ここで Vs... はアダプトするすべてのビュータイプです:

(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

関連項目

イテレータまたは subrange がダングリング状態になるため返すべきではないことを示すプレースホルダ型
(クラス)