Namensräume
Varianten
Aktionen

operator-(ranges::zip_view::sentinel)

Von cppreference.com
< cpp‎ | ranges‎ | zip view‎ | sentinel
 
 
Bereichsbibliothek
Range-Adaptoren
 
 
template< bool OtherConst >

    erfordert (std::sized_sentinel_for<
                ranges::sentinel_t</*maybe-const*/<Const, Views>>,
                ranges::iterator_t</*maybe-const*/<OtherConst, Views>>> && ...)
friend constexpr
    std::common_type_t<ranges::range_difference_t</*maybe-const*/<OtherConst, Views>>...>

operator-( const iterator<OtherConst>& x, const sentinel& y );
(1) (seit C++23)
template< bool OtherConst >

    erfordert (std::sized_sentinel_for<
                ranges::sentinel_t</*maybe-const*/<Const, Views>>,
                ranges::iterator_t</*maybe-const*/<OtherConst, Views>>> && ...)
friend constexpr
    std::common_type_t<ranges::range_difference_t</*maybe-const*/<OtherConst, Views>>...>

operator-( const sentinel& y, const iterator<OtherConst>& x );
(2) (seit C++23)

Berechnet die minimale Distanz zwischen dem zugrundeliegenden Tupel von Iteratoren von x und dem zugrundeliegenden Tupel von Sentinels von y.

Diese Funktionen sind für gewöhnliche unqualifizierte oder qualifizierte Lookups nicht sichtbar und können nur durch Argument-abhängige Suche gefunden werden, wenn zip_view::sentinel<Const> eine zugehörige Klasse der Argumente ist.

[bearbeiten] Parameter

x - ein Iterator
y - ein Sentinel

[bearbeiten] Rückgabewert

Sei current_ das zugrundeliegende Tupel von Iteratoren von x und end_ das zugrundeliegende Tupel von Sentinels von y.

Sei DIST(x, y, i) eine Distanz, die durch einen Ausdruck berechnet wird, der äquivalent ist zu std::get<i>(x.current_) - std::get<i>(y.end_) für eine ganze Zahl i.

1) der Wert mit dem kleinsten Absolutwert unter DIST(x, y, i) für alle i im Bereich 0 ≤ i < sizeof...(Views)
2) -(x - y).

[bearbeiten] Beispiel

#include <cassert>
#include <deque>
#include <list>
#include <ranges>
#include <vector>
 
int main()
{
    auto x = std::vector{1, 2, 3, 4};
    auto y = std::deque{'a', 'b', 'c'};
    auto z = {1.1, 2.2};
    auto w = std::list{1, 2, 3};
 
    auto p = std::views::zip(x, y, z);
    assert(p.begin() - p.end() == +2);
    assert(p.end() - p.begin() == -2);
 
    [[maybe_unused]]
    auto q = std::views::zip(x, y, w);
 
    // The following code fires a compile-time error because std::list::iterator
    // does not support operator- that is needed to calculate the distance:
    // auto e = q.begin() - q.end();
}