命名空间
变体
操作

std::ranges::owning_view

来自 cppreference.com
< cpp‎ | ranges
 
 
范围库
范围适配器
 
在头文件 <ranges> 中定义
template< ranges::range R >

    requires std::movable<R> && (!/*is-initializer-list*/<R>)
class owning_view

    : public ranges::view_interface<owning_view<R>>
(自 C++20 起)

owning_view 是一个 视图,它对一个 范围 具有唯一所有权。它是仅可移动的,并在其内部存储该 范围

在 requires 子句中,常量 /*is-initializer-list*/<R> 当且仅当 std::remove_cvref_t<R>std::initializer_list 的特化时为 true

内容

[编辑] 数据成员

成员名称 定义
r_ (私有) 类型为 R 的底层范围。
(仅供说明的成员对象*)

[编辑] 成员函数

通过对存储的范围进行值初始化或移动构造来构造一个 owning_view
(公共成员函数)
移动赋值存储的范围
(公共成员函数)
返回对存储的范围的引用
(公共成员函数)
返回存储的范围的起始迭代器
(公共成员函数)
返回存储的范围的哨兵
(公共成员函数)
检查存储的范围是否为空
(公共成员函数)
返回存储的 sized_range 的大小
(公共成员函数)
返回指向存储的 contiguous_range 起始位置的指针
(公共成员函数)
std::ranges::view_interface 继承
(C++23)
返回指向范围起始位置的常量迭代器。
(std::ranges::view_interface<D> 的公共成员函数) [编辑]
(C++23)
返回范围的常量迭代器的哨兵。
(std::ranges::view_interface<D> 的公共成员函数) [编辑]
返回派生视图是否为空。如果 ranges::empty 对其适用,则提供。
(std::ranges::view_interface<D> 的公共成员函数) [编辑]
返回派生视图中的第一个元素。如果它满足 forward_range,则提供。
(std::ranges::view_interface<D> 的公共成员函数) [编辑]
返回派生视图中的最后一个元素。如果它满足 bidirectional_rangecommon_range,则提供。
(std::ranges::view_interface<D> 的公共成员函数) [编辑]
返回派生视图中的第 n 个元素。如果它满足 random_access_range,则提供。
(std::ranges::view_interface<D> 的公共成员函数) [编辑]

std::ranges::owning_view::owning_view

owning_view() requires std::default_initializable<R> = default;
(1) (自 C++20 起)
owning_view( owning_view&& other ) = default;
(2) (自 C++20 起)
constexpr owning_view( R&& t );
(3) (自 C++20 起)
owning_view( const owning_view& ) = delete;
(4) (自 C++20 起)
1) 默认构造函数。通过其默认成员初始化器(= R())对存储的范围进行值初始化。
2) 移动构造函数。从 other 的存储范围移动构造存储范围。
3)t 移动构造存储范围。
4) 复制构造函数已删除。owning_view 仅可移动。

参数

other - 要从中移动的另一个 owning_view
t - 要从中移动的范围

std::ranges::owning_view::operator=

owning_view& operator=( owning_view&& other ) = default;
(1) (自 C++20 起)
owning_view& operator=( const owning_view& ) = delete;
(2) (自 C++20 起)
1) 移动赋值运算符。从 other 的存储范围移动赋值存储范围。
2) 复制赋值运算符已删除。owning_view 仅可移动。

参数

other - 要从中移动的另一个 owning_view

返回值

*this

std::ranges::owning_view::base

constexpr R& base() & noexcept;
(1) (自 C++20 起)
constexpr const R& base() const & noexcept;
(2) (自 C++20 起)
constexpr R&& base() && noexcept;
(3) (自 C++20 起)
constexpr const R&& base() const && noexcept;
(4) (自 C++20 起)

返回对存储范围的引用,保留值类别和常量限定。

1,2) 等效于 return r_;.
3,4) 等效于 return std::move(r_);.

std::ranges::owning_view::begin

constexpr ranges::iterator_t<R> begin();
(1) (自 C++20 起)
constexpr auto begin() const requires ranges::range<const R>;
(2) (自 C++20 起)

等效于 return ranges::begin(r_);.

std::ranges::owning_view::end

constexpr ranges::sentinel_t<R> end();
(1) (自 C++20 起)
constexpr auto end() const requires ranges::range<const R>;
(2) (自 C++20 起)

等效于 return ranges::end(r_);.

std::ranges::owning_view::empty

constexpr bool empty() requires requires { ranges::empty(r_); };
(1) (自 C++20 起)
constexpr bool empty() const requires requires { ranges::empty(r_); };
(2) (自 C++20 起)

等效于 return ranges::empty(r_);.

std::ranges::owning_view::size

constexpr auto size() requires ranges::sized_range<R>;
(1) (自 C++20 起)
constexpr auto size() const requires ranges::sized_range<const R>;
(2) (自 C++20 起)

等效于 return ranges::size(r_);.

std::ranges::owning_view::data

constexpr auto data() requires ranges::contiguous_range<R>;
(1) (自 C++20 起)
constexpr auto data() const requires ranges::contiguous_range<const R>;
(2) (自 C++20 起)

等效于 return ranges::data(r_);.

[edit] 辅助模板

template< class T >

constexpr bool enable_borrowed_range<std::ranges::owning_view<T>> =

    ranges::enable_borrowed_range<T>;
(自 C++20 起)

ranges::enable_borrowed_range 的特化使 owning_view 在底层范围满足该要求时满足 borrowed_range

[edit] 示例

#include <cassert>
#include <iostream>
#include <ranges>
#include <string>
 
int main()
{
    using namespace std::literals;
    std::ranges::owning_view ov{"cosmos"s}; // the deduced type of R is std::string;
                                            // `ov` is the only owner of this string
    assert(
        ov.empty() == false &&
        ov.size() == 6 &&
        ov.size() == ov.base().size() &&
        ov.front() == 'c' &&
        ov.front() == *ov.begin() &&
        ov.back() == 's' &&
        ov.back() == *(ov.end() - 1) &&
        ov.data() == ov.base()
    );
 
    std::cout << "sizeof(ov): " << sizeof ov << '\n' // typically equal to sizeof(R)
              << "range-for: ";
    for (const char ch : ov)
        std::cout << ch;
    std::cout << '\n';
 
    std::ranges::owning_view<std::string> ov2;
    assert(ov2.empty());
//  ov2 = ov; // compile-time error: copy assignment operator is deleted
    ov2 = std::move(ov); // OK
    assert(ov2.size() == 6);
}

可能的输出

sizeof(ov): 32
range-for: cosmos

[edit] 另请参阅

对某些其他 range 的元素的 view
(类模板) [edit]
包含 range 中所有元素的 view
(别名模板) (范围适配器对象)[edit]