std::ranges::ref_view
<ranges>
requires std::is_object_v <R>
class ref_view
ref_view
is a view
of the elements of some other range
. It wraps a reference to that range
.
Contents
[edit] Data members
R*
r_
a pointer to the underlying range(exposition-only member object*)
[edit] Member functions
approximately_sized_range
(public member function)
Inherited from std::ranges::view_interface
(public member function of
std::ranges::view_interface<D>
) [edit]
(public member function of
std::ranges::view_interface<D>
) [edit]
(public member function of
std::ranges::view_interface<D>
) [edit]
forward_range
(public member function of
std::ranges::view_interface<D>
) [edit]
bidirectional_range
and common_range
(public member function of
std::ranges::view_interface<D>
) [edit]
n
th element in the derived view, provided only if it satisfies random_access_range
(public member function of
std::ranges::view_interface<D>
) [edit]
std::ranges::ref_view::ref_view
requires std::convertible_to <T, R&> &&
requires { _FUN(std::declval <T>()); }
Initializes r_
with std::addressof (static_cast<R&>(std::forward <T>(t))).
/*different-from*/<T, U> is satisfied if and only if std::remove_cvref_t <T> and std::remove_cvref_t <U> are not the same type, and overloads of _FUN
are declared as void _FUN(R&); void _FUN(R&&) = delete;.
Parameters
std::ranges::ref_view::begin
Returns ranges::begin (*r_
).
std::ranges::ref_view::end
Returns ranges::end (*r_
).
std::ranges::ref_view::empty
requires requires { ranges::empty (*r_); };
Returns ranges::empty (*r_
).
std::ranges::ref_view::size
requires ranges::sized_range <R>;
Returns ranges::size (*r_
).
std::ranges::ref_view::reserve_hint
requires ranges::approximately_sized_range<R>;
Returns ranges::reserve_hint(*r_
).
std::ranges::ref_view::data
requires ranges::contiguous_range <R>;
Returns ranges::data (*r_
).
[edit] Deduction guides
ref_view( R& ) -> ref_view<R>;
[edit] Helper templates
constexpr bool enable_borrowed_range<ranges::ref_view<T>> = true;
This specialization of std::ranges::enable_borrowed_range
makes ref_view
satisfy borrowed_range
.
[edit] Notes
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_ranges_reserve_hint |
202502L |
(C++26) | ranges::approximately_sized_range and reserve_hint
|
[edit] Example
#include <iostream> #include <ranges> int main() { const std::string s{"cosmos"}; const std::ranges::take_view tv{s, 3}; const std::ranges::ref_view rv{tv}; std::cout << std::boolalpha << "call empty(): " << rv.empty() << '\n' << "call size() : " << rv.size() << '\n' << "call begin(): " << *rv.begin() << '\n' << "call end() : " << *(rv.end() - 1) << '\n' << "call data() : " << rv.data() << '\n' << "call base() : " << rv.base().size() << '\n' // ~> tv.size() << "range-for : "; for (const auto c : rv) std::cout << c; std::cout << '\n'; }
Output:
call empty(): false call size() : 3 call begin(): c call end() : s call data() : cosmos call base() : 3 range-for : cos
[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
P2325R3 | C++20 | default constructor was provided asview must be default_initializable
|
removed along with the requirement |