std::ranges::views::values, std::ranges::values_view
Von cppreference.com
| Definiert in der Header-Datei <ranges> |
||
| template< class R > using values_view = ranges::elements_view<R, 1>; |
(1) | (seit C++20) |
| namespace views { inline constexpr auto values = ranges::elements<1>; |
(2) | (seit C++20) |
Nimmt eine view von tuple-ähnlichen Werten (z.B. std::tuple oder std::pair) und erzeugt eine View mit einem value_type des zweiten Elements des value_type der adaptierten View.
1) Ein Alias für ranges::elements_view<R, 1>.
2) RangeAdaptorObject (und auch RangeAdaptorClosureObject). Der Ausdruck views::values(e) ist ausdrucksäquivalent zu values_view<views::all_t<decltype((e))>>{e} für jeden geeigneten Unterausdruck e.
Inhalt |
[bearbeiten] Hinweise
values_view kann nützlich sein, um Werte aus assoziativen Containern zu extrahieren, z.B.
std::map<int, std::string> map{{1, "alpha"}, {2, "beta"}}; for (auto const& value : std::views::values(map)) std::cout << value << ' '; // prints: alpha beta
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <iostream> #include <map> #include <ranges> int main() { const auto list = {std::pair{1, 11.1}, {2, 22.2}, {3, 33.3}}; std::cout << "pair::second values in the list: "; for (double value : list | std::views::values) std::cout << value << ' '; std::map<char, int> map{{'A', 1}, {'B', 2}, {'C', 3}, {'D', 4}, {'E', 5}}; auto odd = [](int x) { return 0 != (x & 1); }; std::cout << "\nodd values in the map: "; for (int value : map | std::views::values | std::views::filter(odd)) std::cout << value << ' '; std::cout << '\n'; }
Ausgabe
pair::second values in the list: 11.1 22.2 33.3 odd values in the map: 1 3 5
[bearbeiten] Defect reports
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 3563 | C++20 | keys_view kann aufgrund der Verwendung von views::all_t nicht an CTAD teilnehmen |
views::all_t entfernt |
[bearbeiten] Siehe auch
| (C++20) |
nimmt einen view von Paar-ähnlichen Werten und erzeugt einen view der ersten Elemente jedes Paares(Klassen-Template) (Range-Adaptor-Objekt) |
nimmt einen view von tuple-ähnlichen Werten und eine Zahl N und erzeugt einen view des N-ten Elements jedes Tupels(Klassen-Template) (Range-Adaptor-Objekt) | |
| BLAS-ähnlicher Slice eines Valarrays: Startindex, Länge, Schrittweite (class) |