std::ranges::views::empty, std::ranges::empty_view
来自cppreference.com
| |
(1) | (C++20 起) |
| |
(2) | (C++20 起) |
1) 产生无特定类型元素的
view 的范围工厂。2)
empty_view 的变量模板。成员函数
begin [静态] |
返回 nullptr (公开静态成员函数) |
end [静态] |
返回 nullptr (公开静态成员函数) |
data [静态] |
返回 nullptr (公开静态成员函数) |
size [静态] |
返回 0 (公开静态成员函数) |
empty [静态] |
返回 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
| |
(C++20 起) | |
empty_view 不引用任何元素。
std::ranges::empty_view::end
| |
(C++20 起) | |
empty_view 不引用任何元素。
std::ranges::empty_view::data
| |
(C++20 起) | |
empty_view 不引用任何元素。
std::ranges::empty_view::size
| |
(C++20 起) | |
empty_view 始终为空。
std::ranges::empty_view::empty
| |
(C++20 起) | |
empty_view 始终为空。
辅助模板
| |
(C++20 起) | |
ranges::enable_borrowed_range 的此特化使得 empty_view 满足 borrowed_range 。
注解
尽管 empty_view 从 view_interface 获得成员函数 front、 back 及 operator[] ,对它们的调用始终导致未定义行为,因为 empty_view 始终为空。
继承的 operator bool 转换函数始终返回 false 。
示例
运行此代码
#include <ranges>
int main()
{
namespace ranges = std::ranges;
ranges::empty_view<long> e;
static_assert(ranges::empty(e)); // 使用 operator bool
static_assert(0 == e.size());
static_assert(nullptr == e.data());
static_assert(nullptr == e.begin());
static_assert(nullptr == e.end());
static_assert(nullptr == e.cbegin());
static_assert(nullptr == e.cend());
}
