std::experimental::ranges::next
来自 cppreference.cn
< cpp | experimental | ranges
namespace { constexpr /* 未指定 */ next = /* 未指定 */; |
(ranges TS) (定制点对象) |
|
调用签名 (Call signature) |
||
template< Iterator I > constexpr I next( I i ); |
(1) | |
template< Iterator I > constexpr I next( I i, ranges::difference_type_t<I> n ); |
(2) | |
template< Iterator I, Sentinel<I> S > constexpr I next( I i, S bound ); |
(3) | |
template< Iterator I, Sentinel<I> S > constexpr I next( I i, ranges::difference_type_t<I> n, S bound ); |
(4) | |
将迭代器 i 向前移动 n 次,或者直到达到 bound,以先发生者为准,并返回前进后的迭代器。
1) 等价于 ++i; return i;。
2) 等价于 ranges::advance(i, n); return i;。
3) 等价于 ranges::advance(i, bound); return i;。
4) 等价于 ranges::advance(i, n, bound); return i;。
目录 |
[编辑] 自定义点对象
名称 ranges::next
表示一个 自定义点对象,它是一个 函数对象,属于一个 字面量 Semiregular
类类型(为便于说明,表示为 NextT
)。NextT
的所有实例都相等。因此,ranges::next
可以自由复制,并且其副本可以互换使用。
给定一组类型 Args...
,如果 std::declval<Args>()... 满足上述 ranges::next
的参数要求,则 NextT
将满足 ranges::Invocable<const NextT, Args...>。否则,NextT
的任何函数调用操作符都不会参与重载解析。
在每个定义 ranges::next
的翻译单元中,它都指向自定义点对象的同一个实例。(这意味着它可以在内联函数和函数模板等中自由使用,而不会违反单一定义规则)。
[编辑] 返回值
前进后的迭代器。
[编辑] 注意
即使省略重载 (2) 的 n 的行为如同 n 为 1,省略重载 (4) 的 n 的行为实际上如同 n 为无穷大(总是前进到 bound)。
[编辑] 示例
本节不完整 原因:无示例 |
[编辑] 参阅
(C++11) |
递增迭代器 (函数模板) |
按给定距离前进迭代器 (函数模板) | |
递减迭代器 (函数模板) | |
返回迭代器与哨兵之间,或范围的起始与结束之间的距离 (函数模板) |