std::ranges::views::empty, std::ranges::empty_view
来自cppreference.com
| |
(1) | (C++20 起) |
| |
(2) | (C++20 起) |
1) 产生无特定类型元素的 view 的范围适配器。
2)
empty_view 的变量模板。辅助模板
| |
||
std::ranges::enable_borrowed_range 的此特化使得 empty_view 满足 borrowed_range 。
成员函数
[静态] |
返回 nullptr (公开静态成员函数) |
[静态] |
返回 nullptr (公开静态成员函数) |
[静态] |
返回 nullptr (公开静态成员函数) |
[静态] |
返回 0 (零) (公开静态成员函数) |
[静态] |
返回 true (公开静态成员函数) |
继承自 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_range 与 common_range 时提供 ( std::ranges::view_interface<D> 的公开成员函数)
| |
返回派生视图中的第 n 个元素,仅当视图满足 random_access_range 时提供 ( std::ranges::view_interface<D> 的公开成员函数)
| |
std::ranges::empty_view::begin
| |
||
empty_view 不引用任何元素。
std::ranges::empty_view::end
| |
||
empty_view 不引用任何元素。
std::ranges::empty_view::data
| |
||
empty_view 不引用任何元素。
std::ranges::empty_view::size
| |
||
empty_view 始终为空。
std::ranges::empty_view::empty
| |
||
empty_view 始终为空。
注解
尽管 empty_view 从 view_interface 获得成员函数 front、 back 及 operator[] ,对它们的调用始终导致未定义行为,因为 empty_view 始终为空。
示例
运行此代码
#include <ranges>
int main()
{
std::ranges::empty_view<long> e;
static_assert(std::ranges::empty(e));
static_assert(0 == e.size());
static_assert(nullptr == e.data());
static_assert(nullptr == e.begin());
static_assert(nullptr == e.end());
}
参阅
| 含有具有指定值的单个元素的 view (类模板) (定制点对象) | |
(C++20) |
包含 range 的所有元素的 view (别名模板) (范围适配器对象) |
(C++20) |
某个其他 range 的元素的 view (类模板) |