operator+,-(ranges::elements_view::iterator)
From cppreference.com
< cpp | ranges | elements view | iterator
C++
Ranges library
|
Range primitives | |||||||
|
Range concepts | |||||||||||||||||||
|
Range factories | |||||||||
|
Range adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|
Helper items | |||||||||||||||||
|
std::ranges::elements_view
Member functions | ||||
Nested classes | ||||
Iterator | ||||
operator+(elements_view::iterator)
operator-(elements_view::iterator) |
||||
Sentinel | ||||
friend
constexpr
/*iterator*/ operator+
(
const
/*iterator*/
& i, difference_type n )
requires ranges::random_access_range <Base> ; |
(1) | (since C++20) |
friend
constexpr
/*iterator*/ operator+
( difference_type n, const
/*iterator*/
& i )
requires ranges::random_access_range <Base> ; |
(2) | (since C++20) |
friend
constexpr
/*iterator*/ operator-
(
const
/*iterator*/
& i, difference_type n )
requires ranges::random_access_range <Base> ; |
(3) | (since C++20) |
friend
constexpr difference_type operator-
(
const
/*iterator*/
& x,
const /*iterator*/& y ) |
(4) | (since C++20) |
1,2) Returns the iterator i incremented by n.
3) Returns the iterator i decremented by n.
4) Returns the distance between x and y.
These functions are not visible to ordinary unqualified or qualified lookup, and can only be found by argument-dependent lookup when elements_view::iterator<Const>
Parameters
i, x, y | - | the iterators |
n | - | position relative to current location |
Return value
1,2)
[
&
]
{
auto j = i; j +
= n;
return j;
}
(
)
3)
[
&
]
{
auto j = i; j -
= n;
return j;
}
(
)
4)
x.base() - y.base()
Example
This section is incomplete Reason: no example |
Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 3483 | C++20 | elements_view::iterator 's difference is overconstrained
|
requirement is relaxed |