iter_swap (std::common_iterator)
|
template
<
std::
indirectly_swappable
<
I
>
I2,
class
S2
>
friend
constexpr
void
|
(seit C++20) | |
Tauscht die Objekte, auf die von zwei zugrundeliegenden Iteratoren gezeigt wird. Das Verhalten ist undefiniert, wenn
x
kein
I
-Objekt enthält oder
y
kein
I2
-Objekt enthält (d.h. mindestens einer von
x
und
y
keinen Iterator enthält).
Der Funktionsrumpf entspricht ranges:: iter_swap ( std :: get < I > ( x. var ) , std :: get < I2 > ( y. var ) ) .
Diese Funktionsvorlage ist für gewöhnliches unqualified oder qualified lookup nicht sichtbar und kann nur durch argument-dependent lookup gefunden werden, wenn std::common_iterator<I,S> eine assoziierte Klasse der Argumente ist.
Inhaltsverzeichnis |
Parameter
| x, y | - | die Iteratoren zu den auszutauschenden Elementen |
Rückgabewert
(keine)
Komplexität
Konstante.
Exceptions
Beispiel
#include <algorithm> #include <iostream> #include <iterator> #include <string> #include <vector> int main() { std::vector<std::string> v1{"1", "2", "3", "4", "5"}, v2{"α", "β", "γ", "δ", "ε"}; using CI = std::common_iterator< std::counted_iterator<std::vector<std::string>::iterator>, std::default_sentinel_t >; CI first1{std::counted_iterator{v1.begin(), 3}}; CI first2{std::counted_iterator{v2.begin(), 4}}; CI last{std::default_sentinel}; auto print = [&](auto rem) { std::cout << rem << "v1 = "; std::ranges::copy(v1, std::ostream_iterator<std::string>{std::cout, " "}); std::cout << "\nv2 = "; std::ranges::copy(v2, std::ostream_iterator<std::string>{std::cout, " "}); std::cout << '\n'; }; print("Before iter_swap:\n"); for (; first1 != last && first2 != last; ++first1, ++first2) iter_swap(first1, first2); // ADL print("After iter_swap:\n"); }
Ausgabe:
Before iter_swap: v1 = 1 2 3 4 5 v2 = α β γ δ ε After iter_swap: v1 = α β γ 4 5 v2 = 1 2 3 δ ε
Fehlerberichte
Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | Angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 3574 | C++20 |
variant
war vollständig constexpr (P2231R1), aber
common_iterator
war es nicht
|
ebenfalls constexpr gemacht |
Siehe auch
|
vertauscht die Werte zweier Objekte
(Funktions-Template) |
|
|
vertauscht zwei Elementbereiche
(Funktions-Template) |
|
|
vertauscht die von zwei Iteratoren referenzierten Elemente
(Funktions-Template) |
|
|
(C++20)
|
vertauscht die von zwei dereferenzierbaren Objekten referenzierten Werte
(Customization Point Object) |
|
(C++20)
|
vertauscht die von zwei zugrundeliegenden Iteratoren referenzierten Objekte
(Funktions-Template) |