Namespaces
Variants

std::ranges:: views:: values, std::ranges:: values_view

From cppreference.net
Ranges library
Range adaptors
Определено в заголовочном файле <ranges>
template < class R >
using values_view = ranges:: elements_view < R, 1 > ;
(1) (начиная с C++20)
namespace views {

inline constexpr auto values = ranges :: elements < 1 > ;

}
(2) (начиная с C++20)

Принимает view кортежеподобных значений (например, std::tuple или std::pair ) и создаёт представление с value-type в виде второго элемента value-type адаптированного представления.

1) Псевдоним для ranges:: elements_view < R, 1 > .
2) RangeAdaptorObject (а также RangeAdaptorClosureObject ). Выражение views :: values ( e ) является эквивалентным по выражению к values_view < views:: all_t < decltype ( ( e ) ) >> { e } для любого подходящего подвыражения e .

Содержание

Примечания

values_view может быть полезен для извлечения значений из ассоциативных контейнеров, например

std::map<int, std::string> map{{1, "alpha"}, {2, "beta"}};
for (auto const& value : std::views::values(map))
    std::cout << value << ' ';
// выводит: alpha beta

Пример

#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';
}

Вывод:

pair::second values in the list: 11.1 22.2 33.3
odd values in the map: 1 3 5

Отчёты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Applied to Behavior as published Correct behavior
LWG 3563 C++20 keys_view не может участвовать в CTAD из-за использования views::all_t views::all_t удалён

Смотрите также

принимает view состоящий из пароподобных значений и создает view первых элементов каждой пары
(шаблон класса) (объект адаптера диапазона)
принимает view состоящий из tuple-like значений и число N, и создает view N -го элемента каждого кортежа
(шаблон класса) (объект адаптера диапазона)
BLAS-подобный срез valarray: начальный индекс, длина, шаг
(класс)