std::ranges::view_interface<D>:: size
|
constexpr
auto
size
(
)
requires
ranges::
forward_range
<
D
>
&&
std::
sized_sentinel_for
<
ranges::
sentinel_t
<
D
>
,
|
(1) | (C++20 起) |
|
constexpr
auto
size
(
)
const
requires
ranges::
forward_range
<
const
D
>
&&
std::
sized_sentinel_for
<
ranges::
sentinel_t
<
const
D
>
,
|
(2) | (C++20 起) |
size()
成员函数的默认实现通过计算哨兵迭代器与起始迭代器的差值来获取区间大小。
目录 |
返回值
to-unsigned-like
(
ranges::
end
(
static_cast
<
D
&
>
(
this
)
)
-
ranges::
begin
(
static_cast
<
D
&
>
(
this
)
)
)
.
to-unsigned-like
(
ranges::
end
(
static_cast
<
const
D
&
>
(
this
)
)
-
ranges::
begin
(
static_cast
<
const
D
&
>
(
this
)
)
)
.
标签内的C++代码均未翻译,仅对数字序号"2)"后的描述性文本进行了本地化处理,将英文说明转换为简体中文表述)
注释
以下派生类型可以使用
size()
的默认实现:
以下类型派生自
std::ranges::view_interface
且未声明自身的
size()
成员函数,但它们无法使用默认实现,因为其迭代器和哨位类型始终不满足
sized_sentinel_for
:
- std::ranges::basic_istream_view
- std::ranges::filter_view
- std::ranges::join_view
- std::ranges::lazy_split_view
- std::ranges::split_view
- std::ranges::take_while_view
缺陷报告
下列行为变更缺陷报告被追溯应用于先前发布的 C++ 标准。
| 缺陷报告 | 适用范围 | 发布时行为 | 正确行为 |
|---|---|---|---|
| LWG 3646 | C++20 |
size
函数的默认实现返回有符号类型
|
返回无符号类型 |
参见
|
(C++17)
(C++20)
|
返回容器或数组的大小
(函数模板) |
|
(C++20)
|
返回等于范围大小的整数
(定制点对象) |
|
(C++20)
|
返回等于范围大小的有符号整数
(定制点对象) |