std::ranges::subrange<I,S,K>::operator PairLike
Von cppreference.com
| template< /*different-from*/<subrange> PairLike > requires /*pair-like-convertible-from*/<PairLike, const I&, const S&> |
(1) | (seit C++20) |
| Hilfskonzepte |
||
template< class T > concept /*pair-like*/ = /* siehe Beschreibung */; |
(2) | (nur Exposition*) |
template< class T, class U, class V > concept /*pair-like-convertible-from*/ = /* siehe Beschreibung */; |
(3) | (nur Exposition*) |
1) Konvertiert
subrange in einen Pair-Like-Typ. Für die Definition von /*different-from*/ siehe
different-from .2) Bestimmt, ob ein Typ Pair-Like ist .
|
Äquivalent zu template< class T > concept /*pair-like*/ = !std::is_reference_v<T> && requires(T t) { typename std::tuple_size<T>::type; requires std::derived_from<std::tuple_size<T>, std::integral_constant<std::size_t, 2>>; typename std::tuple_element_t<0, std::remove_const_t<T>>; typename std::tuple_element_t<1, std::remove_const_t<T>>; { std::get<0>(t) } -> std::convertible_to< const std::tuple_element_t<0, T>&>; { std::get<1>(t) } -> std::convertible_to< const std::tuple_element_t<1, T>&>; }; |
(bis C++23) |
|
Dieses Konzept ist äquivalent zum bibliotheksweiten expositions-only-Konzept pair-like. |
(seit C++23) |
3) Bestimmt, ob ein Pair-Like-Typ aus zwei Werten von möglicherweise unterschiedlichen gegebenen Typen konstruiert werden kann.
|
Äquivalent zu template< class T, class U, class V > concept /*pair-like-convertible-from*/ = !ranges::range<T> && /*pair-like*/<T> && std::constructible_from<T, U, V> && /*convertible-to-non-slicing*/<U, std::tuple_element_t<0, T>> && std::convertible_to<V, std::tuple_element_t<1, T>>; |
(bis C++23) |
|
Äquivalent zu template< class T, class U, class V > concept /*pair-like-convertible-from*/ = !ranges::range<T> && !std::is_reference_v<T> && /*pair-like*/<T> && std::constructible_from<T, U, V> && /*convertible-to-non-slicing*/<U, std::tuple_element_t<0, T>> && std::convertible_to<V, std::tuple_element_t<1, T>>; |
(seit C++23) |
Inhalt |
[edit] Rückgabewert
[edit] Anmerkungen
Folgende Typen in der Standardbibliothek sind Pair-Like:
- std::pair<T, U>
- std::tuple<T, U>
- std::array<T, 2>
- std::ranges::subrange<I, S, K>
|
(seit C++26) |
|
Ein vom Programm definierter Typ, der von einem dieser Typen abgeleitet ist, kann ein Pair-Like-Typ sein, wenn
|
(bis C++23) |
Da subrange-Spezialisierungen range-Typen sind, werden Konvertierungen zu ihnen nicht über diese Konvertierungsfunktion durchgeführt.
std::array-Spezialisierungen können nicht von subrange konvertiert werden, da sie range-Typen sind.
[edit] Beispiel
Führen Sie diesen Code aus
#include <iostream> #include <ranges> #include <string> #include <utility> using striter = std::string::const_iterator; using legacy_strview = std::pair<striter, striter>; void legacy_print(legacy_strview p) { for (; p.first != p.second; ++p.first) std::cout << *p.first << ' '; std::cout << '\n'; } int main() { std::string dat{"ABCDE"}; for (auto v{std::ranges::subrange{dat}}; v; v = {v.begin(), v.end() - 1}) { /*...*/ legacy_print(legacy_strview{v}); } }
Ausgabe
A B C D E A B C D A B C A B A
[edit] Siehe auch
| (C++23) |
gibt an, dass ein Typ das Tuple-Protokoll implementiert (std::get, std::tuple_element, std::tuple_size) (Exposition-only-Konzept*) |